



DFN10

WLCSP-9

Representations only, not actual markings

### **IQS624 Datasheet**

Combination sensor including: Hall-effect rotation sensing, along with dual-channel capactive proximity/touch sensing, or single-channel inductive sensing.

The IQS624 ProxFusion® IC is a multifunctional capacitive and Hall-effect sensor designed for applications where any or all of the technologies may be required. The two Hall-effect sensors calculate the angle of a magnet rotating parallel with the sensor. The sensor is fully I²C compatible and on-chip calculations enable the IC to stream the current angle of the magnet without extra calculations.

#### **Features**

#### Hall effect angle sensor:

- On-chip Hall plates
- o 360° Absolute Output
- 1° Resolution\*, calculated on chip
- o Relative rotation angle.
- Detect movement and the direction of movement.
- Raw data: can be used to calculate degrees on external processor.
- Wide operational range
- No external components required

#### • Partial auto calibration:

- Continuous auto-calibration, compensation for wear or small displacements of the sensor or magnet.
- Flexible gain control
- Automatic Tuning Implementation (ATI)
   Performance enhancement (10 bit).

#### Capacitive sensing

- Full auto-tuning with adjustable sensitivity
- 2pF to 200pF external capacitive load capability

#### **Inductive sensing**

 Only external sense coil required (PCB trace)

### Multiple integrated UI

- Proximity / Touch
- Proximity wake-up
- Event mode
- Wake Hall sensing on proximity
- Minimal external components
- Standard I<sup>2</sup>C interface
- Optional RDY indication for event mode operation
- Low power consumption:
- 240uA (100Hz response, Hall),
- 55uA (100Hz response, capacitive),
- 65uA (20Hz response, Hall)
- 15uA (20Hz response, capacitive)
- 5uA (5Hz response, capacitive)
- Supply Voltage: 2.0V to 3.6V\*\*

\*Optimal conditions

#### **Applications**

- Anemometer
- Dial or Selector knob
- Mouse wheel

- Measuring wheel
- Digital angle gauge
- Speedometer for bicycle

| Available Packages |                          |             |  |  |  |  |
|--------------------|--------------------------|-------------|--|--|--|--|
| T <sub>A</sub>     | DFN(3x3)-10              | WLCSP-9     |  |  |  |  |
| -20°C to 85°C      | IQS624-xzyy <sup>1</sup> | IQS624-32yy |  |  |  |  |

<sup>&</sup>lt;sup>1</sup>All versions

<sup>\*\*5</sup>V solution available on demand.





### **Contents**

| LIS | T OF | ABBREVIATIONS                                      | 4  |
|-----|------|----------------------------------------------------|----|
| 1.  | IN   | NTRODUCTION                                        | 5  |
|     | 1.1  | ProxFusion®                                        | 5  |
|     | 1.2  | PACKAGING AND PIN-OUT                              | 5  |
|     | 1.3  | Reference schematic                                | 7  |
|     | 1.4  | SENSOR CHANNEL COMBINATIONS                        | 7  |
|     | 1.5  | ProxFusion® Sensitivity                            | 8  |
| 2.  | CA   | APACITIVE SENSING                                  | 9  |
|     | 2.1  | Introduction                                       | g  |
|     | 2.2  | CHANNEL SPECIFICATIONS                             | g  |
|     | 2.3  | HARDWARE CONFIGURATION                             | 10 |
|     | 2.4  | Register configuration                             |    |
| :   | 2.5  | SENSOR DATA OUTPUT AND FLAGS                       | 11 |
| 3.  | IN   | NDUCTIVE SENSING                                   | 12 |
| :   | 3.1  | Introduction to inductive sensing                  | 12 |
|     | 3.2  | CHANNEL SPECIFICATIONS                             | 12 |
|     | 3.3  | HARDWARE CONFIGURATION                             |    |
|     | 3.4  | Register configuration                             | 13 |
| :   | 3.5  | SENSOR DATA OUTPUT AND FLAGS                       | 13 |
| 4.  | Н    | ALL-EFFECT SENSING                                 | 14 |
|     | 4.1  | Introduction to Hall-effect sensing                | 14 |
|     | 4.2  | CHANNEL SPECIFICATIONS                             | 14 |
|     | 4.3  | HARDWARE CONFIGURATION                             | 15 |
|     | 4.4  | REGISTER CONFIGURATION                             | 15 |
|     | 4.5  | SENSOR DATA OUTPUT AND FLAGS                       | 16 |
|     | 4.6  | IQS624-32 Interval UI                              | 17 |
|     | 4.7  | IQS624-32 EXAMPLE                                  | 18 |
|     | 4.8  | IQS624-32 WHEEL WAKE PRELOAD (0x7C)                | 19 |
|     | 4.9  | IQS624-32 EVENT MODE OPTIONS                       | 20 |
| 5.  | DI   | EVICE CLOCK, POWER MANAGEMENT AND MODE OPERATION   | 21 |
|     | 5.1  | DEVICE MAIN OSCILLATOR                             | 21 |
|     | 5.2  | DEVICE MODES                                       | 21 |
|     | 5.3  | STREAMING AND EVENT MODE:                          | 22 |
|     | 5.4  | REPORT RATES                                       | 23 |
|     | 5.5  | System reset                                       | 23 |
| 6.  | C    | OMMUNICATION                                       | 24 |
|     | 6.1  | CONTROL BYTE                                       | 24 |
| (   | 6.2  | 12C READ                                           | 24 |
|     | 6.3  | I2C Write                                          | 25 |
|     | 6.4  | END OF COMMUNICATION SESSION / WINDOW              | 25 |
|     | 6.5  | STOP-BIT DISABLE OPTION(IQS624-32)                 | 25 |
| (   | 6.6  | DEVICE ADDRESS AND SUB-ADDRESSES                   |    |
|     | 6.7  | Additional OTP options                             | 26 |
| (   | 6.8  | REQUEST COMMUNICATION WINDOW                       | 27 |
|     | 6.9  | I <sup>2</sup> C Specific Commands                 | 27 |
|     | 6.10 | RECOMMENDED COMMUNICATION AND RUNTIME FLOW DIAGRAM | 28 |
|     |      |                                                    |    |





| 7. IC | QS624 MEMORY MAP                             | 29 |
|-------|----------------------------------------------|----|
| 7.1   | Device Information                           | 32 |
| 7.2   | DEVICE SPECIFIC DATA                         | 33 |
| 7.3   | COUNT DATA                                   | 35 |
| 7.4   | ProxFusion sensor settings                   | 36 |
| 7.5   | Touch / Proximity UI settings                | 39 |
| 7.6   | HALL SENSOR SETTINGS                         | 40 |
| 7.7   | HALL WHEEL OUTPUT                            |    |
| 7.8   | DEVICE AND POWER MODE SETTINGS               | 47 |
| 8. El | LECTRICAL CHARACTERISTICS                    | 51 |
| 8.1   | ABSOLUTE MAXIMUM SPECIFICATIONS              | 51 |
| 8.2   | VOLTAGE REGULATION SPECIFICATIONS            | 51 |
| 8.3   | RESET CONDITIONS                             | 52 |
| 8.4   | DIGITAL INPUT/OUTPUT TRIGGER LEVELS          | 52 |
| 8.5   | Current consumptions                         | 53 |
| 9. P  | ACKAGE INFORMATION                           | 56 |
| 9.1   | DFN10 PACKAGE AND FOOTPRINT SPECIFICATIONS   | 56 |
| 9.2   | WLCSP-9 PACKAGE AND FOOTPRINT SPECIFICATIONS | 57 |
| 9.3   | DEVICE MARKING AND ORDERING INFORMATION      |    |
| 9.4   | TAPE AND REEL SPECIFICATION                  | 59 |
| 9.5   | MSL Level                                    | 61 |
| 10.   | DATASHEET REVISIONS                          | 62 |
| 10.1  | . REVISION HISTORY                           | 62 |
| 10.2  | Prrata                                       | 63 |
| 11.   | CONTACT INFORMATION                          | 64 |
| 12.   | APPENDICES                                   | 65 |
| 12.1  | APPENDIX A: MAGNET ORIENTATION               | 65 |
| 12.2  | APPENDIX B: MAGNET CALIBRATION               | 70 |
| 12.3  | APPENDIX C: HALL ATI                         |    |





### List of abbreviations

PXS - ProxSense®

ATI – Automatic Tuning Implementation

LTA - Long term average

Thr - Threshold

UI - User interface

AC – Alternating current

DSP - Digital signal processing

RX - Receiving electrode

TX - Transmitting electrode

CS - Sampling capacitor

C - Capacitive

NP - Normal power

LP - Low power

ULP - Ultra low power

ACK – I<sup>2</sup>C Acknowledge condition

NACK - I<sup>2</sup>C Not Acknowledge condition

FG - Floating gate





### 1. Introduction

#### 1.1 ProxFusion®

The ProxFusion® sensor series provide all the proven ProxSense® engine capabilities with additional sensors types. A combined sensor solution is available within a single platform.

### 1.2 Packaging and Pin-Out

### 1.2.1 DFN(3x3)-10



Figure 1-1 Pin out of IQS624 DFN (3X3)-10 package.

Table 1-1 IQS624 Pin-out

|     |                       | IQS624 P               | in-out                       |  |  |
|-----|-----------------------|------------------------|------------------------------|--|--|
| Pin | Name                  | Type                   | Function                     |  |  |
| 1   | SDA                   | Digital Input / Output | I <sup>2</sup> C: SDA Output |  |  |
| 2   | RDY Digital Output    |                        | I <sup>2</sup> C: RDY Output |  |  |
| 3   | VDDHI                 | Supply Input           | Supply Voltage Input         |  |  |
| 4   | VREG Regulator Output |                        | Internal Regulator Pin       |  |  |
| 5   | LTX Analogue          |                        | Transmit Electrode 1         |  |  |
| 6   | CRX0                  | Analogue               | Sense Electrode 0            |  |  |
| 7   | CRX1                  | Analogue               | Sense Electrode 1            |  |  |
| 8   | SCL                   | Digital Input / Output | I <sup>2</sup> C: SCL Output |  |  |
| 9   | NC                    | Not connect            | Not connect                  |  |  |
| 10  | VSS                   | Supply Input           | Ground Reference             |  |  |





### 1.1.1 WLCSP-9



Figure 1-2 IQS624 pin-out (WLCSP-9 package top view; markings may differ)

Table 1.1 WLCSP-9 pin-out description

|     | IQS620A in WLCSP-9 |                                                 |                                                                                |  |  |  |  |  |  |  |
|-----|--------------------|-------------------------------------------------|--------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Pin | Name               | Туре                                            | Function                                                                       |  |  |  |  |  |  |  |
| A1  | SCL                | Digital input / output                          | SCL (I <sup>2</sup> C Clock signal)                                            |  |  |  |  |  |  |  |
| A2  | GPIO3 /<br>LTX     | Digital output / Analogue transmitter electrode | Connect to inductive sensor's transmitting coil                                |  |  |  |  |  |  |  |
| А3  | GPIO0 /<br>RDY     | Digital output Open drain active low logic      | RDY (I <sup>2</sup> C Ready interrupt signal)                                  |  |  |  |  |  |  |  |
| B1  | RX1                | Analogue receiving electrode                    | Sense Electrode 1                                                              |  |  |  |  |  |  |  |
| B2  | RX0                | Analogue receiving electrode                    | Sense Electrode 0                                                              |  |  |  |  |  |  |  |
| В3  | SDA                | Digital input / output                          | SDA (I <sup>2</sup> C Data signal)                                             |  |  |  |  |  |  |  |
| C1  | VSS                | Supply input                                    | Common ground reference                                                        |  |  |  |  |  |  |  |
| C2  | VREG               | Voltage regulator output                        | Regulates the system's internal voltage Requires external capacitors to ground |  |  |  |  |  |  |  |
| C3  | VDDHI              | Supply input                                    | Supply Voltage Input                                                           |  |  |  |  |  |  |  |



#### 1.3 Reference schematic



Figure 1-3 IQS624 reference schematic



Figure 1-4 IQS624 WLCSP-9 reference schematic

#### 1.4 Sensor channel combinations

The table below summarizes the IQS624's sensor and channel associations.

CH<sub>0</sub> CH<sub>1</sub> CH<sub>2</sub> CH<sub>3</sub> CH4 CH5 Sensor type **Discreet Self** 0 0 Capacitive Hall effect rotary 2<sup>nd</sup> plate 2<sup>nd</sup> plate 1st plate 1st plate UI Positive Negative Positive Negative **Mutual Inductive** 0 0

Table 1-2 Sensor - channel allocation

#### Key:

- Optional implementation
- Fixed use for UI





### 1.5 ProxFusion® Sensitivity

The measurement circuitry uses a temperature stable internal sample capacitor ( $C_S$ ) and internal regulated voltage ( $V_{REG}$ ). Internal regulation provides for more accurate measurements over temperature variation. The size of the sample capacitor can be decreased to increase sensitivity on the capacitive channels of the IQS624.

Sensitivity 
$$\propto \frac{1}{C_s}$$

The Automatic Tuning Implementation (ATI) is a sophisticated technology implemented on the ProxFusion® series devices. It allows for optimal performance of the devices for a wide range of sense electrode capacitances, without modification or addition of external components. The ATI functionality ensures that sensor sensitivity is not affected by external influences such as temperate, parasitic capacitance and ground reference changes.

The ATI process adjusts three values (Coarse multiplier, Fine multiplier, Compensation) using two parameters (ATI base and ATI target) as inputs. A 10-bit compensation value ensures that an accurate target is reached. The base value influences the overall sensitivity of the channel and establishes a base count from where the ATI algorithm starts adding compensation. A rough estimation of sensitivity can be calculated as:

$$Sensitivity \propto \frac{Target}{Base}$$

As seen from this equation, the sensitivity can be increased by either increasing the Target value or decreasing the Base value. A lower base value will typically result in lower multipliers and more compensation would be required. It should, however, be noted that a higher sensitivity will yield a higher noise susceptibility. Refer to <a href="Appendix B">Appendix B</a> and <a href="Appendix C">Appendix C</a> for more information on Hall ATI.





## 2. Capacitive sensing

### 2.1 Introduction

Building on the previous successes from the ProxSense® range of capacitive sensors, the same fundamental sensor engine has been implemented in the ProxFusion® series.

### 2.2 Channel specifications

The IQS624 provides a maximum of 2 channels available to be configured for capacitive sensing. Each channel can be setup separately using the channel's associated settings registers.

Table 2-1 Capacitive sensing - channel allocation

| Sensor type              | СН0 | CH1 | CH2 | СНЗ | CH4 | CH5 |
|--------------------------|-----|-----|-----|-----|-----|-----|
| Discreet Self Capacitive | 0   | 0   |     |     |     |     |

Key:

Optional implementation

- Optional implementation
- Fixed use for UI





## 2.3 Hardware configuration

In the table below are two options of configuring sensing (Rx) electrodes.

**Table 2-2 Capacitive hardware description** 



## 2.4 Register configuration

### 2.4.1 Registers to configure for the capacitive sensing:

**Table 2-3 Capacitive sensing settings registers** 

| Address           | Name                             | Description                                       | Recommended setting                                       |  |
|-------------------|----------------------------------|---------------------------------------------------|-----------------------------------------------------------|--|
| 0x40, 0x41        | Ch0/Ch1 ProxFusion<br>Settings 0 | Sensor mode and configuration of each             | Sensor mode should be set to capacitive mode              |  |
| <u>0x40, 0x41</u> |                                  | channel.                                          | An appropriate RX should be chosen and no TX              |  |
| <u>0x42</u>       | Ch0&Ch1 ProxFusion<br>Settings 1 | Global settings for the ProxFusion sensors        | None                                                      |  |
| 0x43, 0x44        | Ch0/Ch1 ProxFusion<br>Settings 2 | ATI settings for<br>ProxFusion sensors            | ATI target should be more than ATI base to achieve an ATI |  |
| <u>0x45</u>       | Ch0&Ch1 ProxFusion<br>Settings 3 | Additional Global settings for ProxFusion sensors | AC filter should be enabled                               |  |
| <u>0x50, 0x52</u> | Proximity threshold              | Proximity Threshold for UI                        | Preferably more than touch threshold                      |  |
| 0x51, 0x53        | Touch threshold                  | Touch Threshold for UI                            | None                                                      |  |





### 2.4.2 Proximity Thresholds

A proximity threshold for both channels can be selected for the application, to obtain the desired proximity trigger level. The proximity threshold is selectable between 1 (most sensitive) and 255 (least sensitive) counts. These threshold values (i.e. 1-255) are specified in Counts (CS) in the Ch0 Proximity threshold (0x50) and Ch1 Proximity threshold (0x51) registers for the discreet button UI.

#### 2.4.3 Touch Thresholds

A touch threshold for each channel can be selected by the designer to obtain the desired touch sensitivity and is selectable between 1/256 (most sensitive) to 255/256 (least sensitive). The touch threshold is calculated as a fraction of the Long-Term Average (LTA) given by,

$$T_{THR} = \frac{x}{256} \times LTA$$

With lower target values (therefore lower LTA's) the touch threshold will be lower and vice versa.

Individual touch thresholds can be set for each channel, by writing to the <u>Ch0 Touch threshold</u> (0x51) and <u>Ch1 Touch threshold</u> (0x53) for the discreet button UI.

#### 2.4.4 Example code:

Example code for an Arduino Uno can be downloaded at:

www.azoteq.com//images/stories/software/IQS62x\_Demo.zip

### 2.5 Sensor data output and flags

The following register should be monitored by the master to detect capacitive sensor output.

a) The <u>Proximity/Touch UI Flags (0x12)</u> provide more detail regarding the outputs. A proximity and touch output bit for each channel 0 and 1 is provided in the Proximity/Touch UI Flags register.

| Proximity/Touch UI Flags (0x12) |   |      |                           |                           |   |   |                            |                            |  |  |
|---------------------------------|---|------|---------------------------|---------------------------|---|---|----------------------------|----------------------------|--|--|
| Bit Number                      | 7 | 6    | 5                         | 4                         | 3 | 2 | 1                          | 0                          |  |  |
| Data Access                     |   | Read |                           |                           |   |   |                            |                            |  |  |
| Name                            |   |      | Chan<br>1<br>Touch<br>out | Chan<br>0<br>touch<br>out |   |   | Chan 1<br>proximity<br>out | Chan 0<br>proximity<br>out |  |  |





## 3. Inductive sensing

### 3.1 Introduction to inductive sensing

The IQS624 provides inductive sensing capabilities to detect the presence of metal/metal-type objects.

### 3.2 Channel specifications

The IQS624 requires 3 sensing lines for mutual inductive sensing.

A single inductance user interface is available.

a) Discreet proximity/touch UI (always enabled)

Table 3-1 Mutual inductive sensor – channel allocation

| Mode             | СН0 | CH1 | CH2 | СНЗ | CH4 | CH5 |
|------------------|-----|-----|-----|-----|-----|-----|
| Mutual inductive | 0   | 0   |     |     |     |     |

#### Key:

- o Optional implementation
- - Fixed use for UI

### 3.3 Hardware configuration

Rudimentary hardware configurations (to be completed).

**Table 3-2 Mutual inductive hardware description** 







## 3.4 Register configuration

Table 3-3 Inductive sensing settings registers.

| Address           | Name                             | Description                                       | Recommended setting                                       |  |  |
|-------------------|----------------------------------|---------------------------------------------------|-----------------------------------------------------------|--|--|
|                   | Ch0/Ch1 ProxFusion Settings 0    | Sensor mode and configuration of each             | Sensor mode should be set to Inductive mode               |  |  |
| <u>0x40, 0x41</u> |                                  | channel.                                          | Choose one channel and deactivate the other channel       |  |  |
|                   |                                  |                                                   | Enable both RX for the activated channel                  |  |  |
| <u>0x42</u>       | Ch0&Ch1 ProxFusion<br>Settings 1 | Global settings for the ProxFusion sensors        | CS divider should be enabled                              |  |  |
| <u>0x43, 0x44</u> | Ch0/Ch1 ProxFusion<br>Settings 2 | ATI settings for ProxFusion sensors               | ATI target should be more than ATI base to achieve an ATI |  |  |
| <u>0x45</u>       | Ch0&Ch1 ProxFusion<br>Settings 3 | Additional Global settings for ProxFusion sensors | None                                                      |  |  |
| <u>0x50, 0x52</u> | Proximity threshold              | Proximity Threshold for UI                        | Less than touch threshold                                 |  |  |
| <u>0x51, 0x53</u> | Touch threshold                  | Touch Threshold for UI None                       |                                                           |  |  |

### 3.4.1 Example code:

Example code for an Arduino Uno can be downloaded at:

www.azoteq.com//images/stories/software/IQS62x Demo.zip

## 3.5 Sensor data output and flags

The following register should be monitored by the master to detect capacitive sensor output.

a) The <u>Proximity/Touch UI Flags (0x12)</u> provide more detail regarding the outputs. A proximity and touch output bit for each channel 0 and 1 is provided in the Proximity/Touch UI Flags register.

| Proximity/Touch UI Flags (0x12) |      |   |                           |                           |   |   |                            |                            |  |
|---------------------------------|------|---|---------------------------|---------------------------|---|---|----------------------------|----------------------------|--|
| Bit Number                      | 7    | 6 | 5                         | 4                         | 3 | 2 | 1                          | 0                          |  |
| Data Access                     | Read |   |                           |                           |   |   |                            |                            |  |
| Name                            |      |   | Chan<br>1<br>Touch<br>out | Chan<br>0<br>touch<br>out |   |   | Chan 1<br>proximity<br>out | Chan 0<br>proximity<br>out |  |





## 4. Hall-effect sensing

### 4.1 Introduction to Hall-effect sensing

The IQS624 has two internal Hall-effect sensing plates (on die). No external sensing hardware is required for Hall-effect sensing.

The Hall-effect sensor measures the generated voltage difference across the plate, which can be modelled as a Wheatstone bridge. The voltage difference is converted to a current using an operational amplifier in order to be measured by the same ProxSense® sensor engine.

Advanced digital signal processing is performed to provide sensible output data.

- Calculates absolute position in degrees.
- Auto calibration attempts to linearize degrees output on the fly
- Differential Hall-Effect sensing:
  - Removes common mode disturbances

Refer to the Errata for correct setup of the IC.

### 4.2 Channel specifications

Channels 2 to 5 are dedicated to Hall-effect sensing. Channel 2 & 4 performs the positive direction measurements while channel 3 & 5 handle all measurements in the negative direction. Differential data is obtained from these four channels. This differential data is used as input data to calculate the output angle of the Hall-effect rotation UI. Channel 2 & 3 is used for the one plate and channel 4 & 5 for the second plate.

Table 4-1 Hall-effect sensor – channel allocation

| Mode              | СН0 | CH1 | CH2                                    | СН3                                    | CH4                                    | CH5                                    |
|-------------------|-----|-----|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|
| Hall rotary<br>UI |     |     | •<br>1 <sup>st</sup> plate<br>Positive | •<br>1 <sup>st</sup> plate<br>Negative | •<br>2 <sup>nd</sup> plate<br>Positive | •<br>2 <sup>nd</sup> plate<br>Negative |

#### Key:

- O Optional implementation
- Fixed use for UI





## 4.3 Hardware configuration

Rudimentary hardware configurations. For more detail and alternative placement options, refer to Appendix A.



### 4.4 Register configuration

For more detail on the setup of the IQS624 refer to Appendix B.

Table 4-2 Hall sensing settings registers

| Address          | Name                           | Description                            | Recommended setting                                                      |  |  |  |  |  |
|------------------|--------------------------------|----------------------------------------|--------------------------------------------------------------------------|--|--|--|--|--|
| <u>0x70</u>      | Hall Rotation UI<br>Settings   | Hall wheel UI settings                 | Hall UI should be enabled for degree output; enable Auto Calibration     |  |  |  |  |  |
| <u>0x71</u>      | Hall sensor settings           | Auto ATI and charge frequency settings | Auto ATI should be enabled for temperature drift compensation            |  |  |  |  |  |
| <u>0x72,0x73</u> | Hall ATI Settings <sup>1</sup> | Hall channels ATI settings             | ATI Target should be more than base                                      |  |  |  |  |  |
| <u>0x78</u>      | Hall ratio Settings            | Invert Direction setting for Hall UI   | None                                                                     |  |  |  |  |  |
| <u>0x79</u>      | Sin(phase)<br>constant         | Sin phase calibration value            | Calculate this value using the GUI or the calculations in the Appendix A |  |  |  |  |  |

<sup>&</sup>lt;sup>1</sup> Refer to the <u>errata</u> and <u>Appendix B</u>





| <u>0x7A</u>   | Cos(phase)<br>constant | Cos phase calibration value        | Calculate this value using the GUI or the calculations in the Appendix A |  |  |  |  |
|---------------|------------------------|------------------------------------|--------------------------------------------------------------------------|--|--|--|--|
| <u>0x7B</u> 1 | Wheel Filter Beta      | Degree filter value                | Adjust filter value based on the amount of noise on the degree value     |  |  |  |  |
| <u>0x7C</u> 1 | Wheel Wake<br>Preload  | Wheel wakeup settings              | Use default values                                                       |  |  |  |  |
| <u>0x7D</u> 1 | Interval UI Divider    | Divider for filtered degree values | Depending on the application (should be equal or greater than 3)         |  |  |  |  |
| <u>0x7E</u> 1 | Wheel Offset           | Wheel offset from zero position    | Can be used for accurate intervals                                       |  |  |  |  |

#### 4.4.1 Example code:

Example code for an Arduino Uno can be downloaded at:

www.azoteg.com//images/stories/software/IQS62x Demo.zip

For ARM mbed resources refer to:

https://os.mbed.com/components/IQS624/

### 4.5 Sensor data output and flags

a) The Hall UI Flags (0x14) register. Bit7 is dedicated to indicating a movement of the magnet. Bit6 indicates the direction of the movement. Bit 1 is set when the movement counts are negative and bit 0 is set when the relative angle is negative. Bit 6 can be used to determine the magnet direction.

|             | Hall UI Flags (0x14) |                    |   |   |   |   |   |   |  |  |  |  |  |  |  |
|-------------|----------------------|--------------------|---|---|---|---|---|---|--|--|--|--|--|--|--|
| Bit Number  | 7                    | 6                  | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |
| Data Access |                      | Read               |   |   |   |   |   |   |  |  |  |  |  |  |  |
| Name        | Wheel movement       | Movement direction |   |   |   |   |   |   |  |  |  |  |  |  |  |

b) The <u>Filtered Degree Output (0x17-0x16)</u> A 16-bit value for the filtered degrees can be read from these registers. (0-359 degrees)

|             |    |                                                                |  | Fil | ltered | d Deg | Filtered Degree Output <sup>1</sup> (0x17-0x16) |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------|----|----------------------------------------------------------------|--|-----|--------|-------|-------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit Number  | 15 | 14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |  |     |        |       |                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Data Access |    | Read                                                           |  |     |        |       |                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name        |    | Degrees High Byte Degrees Low Byte                             |  |     |        |       |                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### Bit definitions:

• 0-360: Filtered absolute degree position of magnet

c) The <u>Interval Number (0x18)</u> An 8-bit value for the current interval number can be read from this register.

|            | Interval Number <sup>1</sup> (0x18) |   |   |   |   |   |   |   |  |  |  |  |  |  |
|------------|-------------------------------------|---|---|---|---|---|---|---|--|--|--|--|--|--|
| Bit Number | 7                                   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |

<sup>&</sup>lt;sup>1</sup> Only Available on IQS624-32





| Data Access | Read/Write              |
|-------------|-------------------------|
| Name        | Current Interval Number |

- Bit 7-0: Current interval number
- d) The <u>Degree Output (0x81-0x80)</u>. A 16-bit value for the degrees can be read from these registers. (0-360 degrees)

|             |    |                                    | Degree Output (0x81-0x80) |  |  |  |   |      |        |   |  |  |  |  |  |  |
|-------------|----|------------------------------------|---------------------------|--|--|--|---|------|--------|---|--|--|--|--|--|--|
| Bit Number  | 15 | 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |                           |  |  |  |   |      |        |   |  |  |  |  |  |  |
| Data Access |    |                                    |                           |  |  |  | I | Read | /Write | ) |  |  |  |  |  |  |
| Name        |    | Degrees High Byte Degrees Low Byte |                           |  |  |  |   |      |        |   |  |  |  |  |  |  |

e) The <u>Relative Rotation Angle (0x8E)</u>. The delta in degrees from the previous cycle to the current cycle can be read from this register. (0-180 degrees)

|             |   |                  | Relative I | Rotation A | ngle (0x8 | E) |  |  |  |  |  |  |  |
|-------------|---|------------------|------------|------------|-----------|----|--|--|--|--|--|--|--|
| Bit Number  | 7 | 7 6 5 4 3 2 1 0  |            |            |           |    |  |  |  |  |  |  |  |
| Data Access |   |                  |            | Read       | /Write    |    |  |  |  |  |  |  |  |
| Name        |   | Relative degrees |            |            |           |    |  |  |  |  |  |  |  |

#### 4.6 IQS624-32 Interval UI

The IQS624-32 offers a new on-chip interval UI specifically designed for applications with discreet mechanical intervals or reduced resolution requirements.

#### 4.6.1 Interval UI Features

- Adjustable interval size (3°-180°)
- The wheel can be zeroed at startup
- Adjustable wheel offset value
- An event is generated for changes to the Interval Number Register (0x18)

#### 4.6.2 Interval UI Settings Registers

|                |                             | Ha                                     | II Rotatio                 | n UI Settings                               | s (0x70)                                  |                  |   |                 |  |  |  |  |  |  |
|----------------|-----------------------------|----------------------------------------|----------------------------|---------------------------------------------|-------------------------------------------|------------------|---|-----------------|--|--|--|--|--|--|
| Bit Number     | 7 6 5 4 3 2 1               |                                        |                            |                                             |                                           |                  |   |                 |  |  |  |  |  |  |
| Data<br>Access |                             | Read/Write                             |                            |                                             |                                           |                  |   |                 |  |  |  |  |  |  |
| Name           | Hall<br>Wheel<br>UI disable | Interval<br>UI<br>disable <sup>1</sup> | Zero<br>Wheel <sup>1</sup> | Hall Wheel<br>Event<br>disable <sup>1</sup> | Interval<br>Event<br>Disable <sup>1</sup> | Auto calibration | ı | Wheel<br>wakeup |  |  |  |  |  |  |
| UI Setting     | 0                           | 0                                      | 0                          | 1                                           | 0                                         | 1                | - | 0               |  |  |  |  |  |  |

#### Bit definitions:

Bit 5: Zero Wheel angle<sup>1</sup>

1: Zero angle, automatically cleared by firmware

Bit 3: Interval UI Event disable<sup>1</sup>

o 0: Event UI is enabled

o 1: Event UI is disabled

<sup>&</sup>lt;sup>1</sup> Only Available on IQS624-32





|             |   |                 | Interva | I UI Divide  | er¹ (0x7D)  |    |  |  |  |  |  |  |  |
|-------------|---|-----------------|---------|--------------|-------------|----|--|--|--|--|--|--|--|
| Bit Number  | 7 | 7 6 5 4 3 2 1 0 |         |              |             |    |  |  |  |  |  |  |  |
| Data Access |   | Read/Write      |         |              |             |    |  |  |  |  |  |  |  |
| Name        |   |                 | l:      | nterval size | e in degree | es |  |  |  |  |  |  |  |
| Default     |   | 3               |         |              |             |    |  |  |  |  |  |  |  |

#### Bit definitions:

- Bit 7-0: Interval size in degrees (>= 3° and <=180°)</li>
  - The <u>Interval Number (0x18)</u> <sup>1</sup> An 8-bit value for the current interval number can be read from this register.

|             |    |                                              |  |  | W | heel | Offse | t <sup>1</sup> (0) | 7E-0 | x7F) |  |  |  |  |  |  |
|-------------|----|----------------------------------------------|--|--|---|------|-------|--------------------|------|------|--|--|--|--|--|--|
| Bit Number  | 15 | 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0           |  |  |   |      |       |                    |      |      |  |  |  |  |  |  |
| Data Access |    | Read                                         |  |  |   |      |       |                    |      |      |  |  |  |  |  |  |
| Name        |    | Wheel Offset High Byte Wheel Offset Low Byte |  |  |   |      |       |                    |      |      |  |  |  |  |  |  |
| Default     |    | 0                                            |  |  |   |      |       |                    |      |      |  |  |  |  |  |  |

#### Bit definitions:

0-360: Wheel offset in degrees

#### 4.6.3 Interval UI Output Register

|             | Interval Number <sup>1</sup> (0x18) |                         |  |      |        |  |  |  |  |  |  |  |  |
|-------------|-------------------------------------|-------------------------|--|------|--------|--|--|--|--|--|--|--|--|
| Bit Number  | 7                                   | 7 6 5 4 3 2 1 0         |  |      |        |  |  |  |  |  |  |  |  |
| Data Access |                                     |                         |  | Read | /Write |  |  |  |  |  |  |  |  |
| Name        |                                     | Current Interval Number |  |      |        |  |  |  |  |  |  |  |  |

Bit 7-0: Current interval number

### 4.7 IQS624-32 Example

Figure 4-1 illustrates an example wheel with 10 intervals. The IQS624-32 can be configured to generate an event on each interval. Configure the following registers for setup:

- 1. Disable Hall Wheel Event and Enable Interval Event in Hall Rotation Settings (0x70)
  - Write 0x14 to register 0x70
- 2. Set Interval UI Divider (0x7D) to 36D ( $360^{\circ}/36^{\circ} = 10$  intervals)
  - Write 0x24 to register to 0x7D
- 3. If required, the wheel can be zeroed at startup in Hall Rotation UI Settings (0x70)
  - Set Bit5 in 0x70
- 4. The interval register will increment every 36 degrees. If the wheel is zeroed using discrete mechanical intervals (Figure 4-1), half an interval should be added to the Wheel Zero Offset (0x7E-0x7F). With this offset, the interval register should increment when the wheel has moved half of the interval as shown by B in Figure 4-1.
- 5. Enable Event Mode in General System Settings (0xD0)

<sup>&</sup>lt;sup>1</sup> Only Available on IQS624-32





- Set Bit5 in 0xD0
- 6. The interval can be read from the Interval Number (0x18) register.



**Figure 4-1: Discrete Mechanical Intervals** 

A 1-degree hysteresis is applied in the direction of rotation, resulting in two degrees of hysteresis at the interval change. This reduces the influence of jitter. In Figure 4-2, the interval will increase when point C is reached and will only decrease when the wheel moves back to point A. In this example  $A = 35^{\circ}$ ;  $B = 36^{\circ}$ ;  $C = 37^{\circ}$ .



Figure 4-2: Interval UI Hysteresis

### 4.8 IQS624-32 Wheel Wake Preload (0x7C)

This register was added to improve performance. This register is compared to the Movement counter/timer (0x8F) register. The wheel will wake up if the counter value reaches the counter threshold value before the timer reaches 0. The timer in register 0x8F will count down from the value set in the **Wheel Wake Timer Preload.** The **Counter Threshold** is the amount of degrees the wheel





has to move before an event is generated for movement. The wheel movement and movement direction bits in the Hall UI Flags (0x14) register also responds to this register.

The **Wheel Wake Timer Preload** can also be set to zero. In this mode the wheel will wake up if the wheel has moved the amount of degrees specified in the **Counter Threshold**. When the wheel is awake, 31 will be loaded in the **Wheel Wake Timer Preload**.

### 4.9 IQS624-32 Event Mode Options

The IQS624-32 provides three event mode options, these are:

#### 1. Touch on Wheel Wakeup enabled (Bit0, 0x70)

- The device wakes up from the low-power modes when there is a touch on Ch0.
- In normal power mode events are only generated when there is a touch on Ch0.
   Ready events will be continuously generated as long as there is a touch on Ch0. If Touch on Wheel is enabled Interval and Hall Wheel Events are ignored.

#### 2. Interval Event (Bit3, 0x70)

- The device wakes up from low-power modes when the wheel increment or decrement the interval register.
- Ready events are generated in normal power mode when the interval changes. If Interval Events and Hall Wheel Events (below) are enabled the IC will respond to Hall Wheel Events.

#### 3. Hall Wheel Event (Bit4, 0x70)

- The device wakes up based on the conditions described in Section 4.7. The wheel will wake up if the counter value reaches the counter threshold value before the timer reaches 0.
- Events are generated on the same condition when the device is in low power mode.
   If Hall Wheel Events and Interval Events are enabled the IC will respond to Hall Wheel Events.

The device can also be set to **Stream in Normal Power (Bit5, 0xD9).** With this bit set the device will wake up from either of the selected modes above. Events will be generated based on the Normal Power Report Rate during Normal Power mode. The device will stop streaming when low-power mode is entered.

**Table 4-3: Hall Rotation UI Settings** 

|                       | Hall Rotation UI Settings (0x70) |
|-----------------------|----------------------------------|
| Touch on Wheel Wakeup | 0x1D                             |
| Interval Event        | 0x14                             |
| Hall Wheel Event      | 0x0C                             |

If all of these modes are disabled, there will be no events generated for wheel movements.





## 5. Device clock, power management and mode operation

#### 5.1 Device main oscillator

The IQS624 has a **16MHz** main oscillator (default enabled) to clock all system functionality.

An option exists to reduce the main oscillator to 8MHz. This will result in charge transfers to be slower by half of the default implementations.

To set this option:

- As a software setting Set the <u>General System Settings (0xD0)</u>: bit4 = 1, via an I<sup>2</sup>C command.
- As a permanent setting Set the OTP option in FG Bank 0: bit2 = 1, using Azoteq USBProg program.

The ProxFusion® channels charges at half of the main oscillator frequency. Therefore the frequency multiplier selected in <a href="Ch0&1 ProxFusion Settings 1">Ch0&1 ProxFusion Settings 1</a> (0x42; bit 4-5) and <a href="Hall sensor settings">Hall sensor settings</a> (0x71; bit 4-5) is multiplied by half of the main oscillator frequency.

#### 5.2 Device modes

The IQS624 supports the following modes of operation;

- **Normal mode** (Fixed report rate)
- Low Power mode (Reduced report rate, no UI execution)
- Ultra-Low Power mode (Only channel 0 is sensed for a prox)
- Halt Mode (Suspended/disabled)

Note: Auto modes must be disabled to enter or exit halt mode.

The device will automatically switch between the different operating modes by default. However, this Auto mode feature may be disabled by setting the Disable Auto Modes bit (<u>Power Mode Settings 0xD2; bit 5</u>) to confine device operation to a specific power mode. The Power Mode bits (<u>Power Mode Settings 0xD2; bit 3-4</u>) can then be used to specify the desired mode of operation.

#### 5.2.1 Normal mode

Normal mode is the fully active sensing mode to function at a fixed report rate specified in the Normal Mode report rate (0xD3) register. This 8-bit value is adjustable from 0ms – 255ms in intervals of 1ms.

#### 5.2.2 Low power mode

Low power mode is a reduced sensing mode where all channels are sensed but no UI code are executed. The sample rate can be specified in the <u>Low Power Mode report rate (0xD4)</u> register. The 8-bit value is adjustable from 0ms – 255ms in intervals of 1ms. Reduced report rates also reduce the current consumed by the sensor.

#### 5.2.3 Ultra-low power mode

Ultra-low power mode is a reduced sensing mode where only channel 0 is sensed and no other channels or UI code are executed. Set the Enable ULP Mode bit (<u>Power Mode Settings 0xD2</u>; <u>bit 6</u>) to enable use of the ultra-low power mode. The sample rate can be specified in the <u>Low Power Mode report rate (0xD5)</u> register. The 8-bit value is adjustable from 0ms – 4sec in intervals of 16ms.

When in Ultra-low power mode the IQS624 can be configured to update all channels at a specific rate defined in <a href="Power Mode Settings">Power Mode Settings</a> (0xD2) register. A flag will be set in the <a href="System flags">System flags</a> (0x10;





<u>bit 0)</u> register when a normal power update is performed. Wake up will occur on proximity detection on channel 0. Ultra-low power mode will not function properly if channel 0 is not enabled.

#### 5.2.4 Halt mode

Halt mode will suspend all sensing and will place the device in a dormant or sleep state. The device requires an I<sup>2</sup>C command from a master to explicitly change the power mode out of the halt state before any sensor functionality can continue.

#### 5.2.5 Mode time

The mode time is specified in the <u>Auto Mode Timer (0xD6)</u> register. The 8-bit value is adjustable from 0ms - 2min in intervals of 500ms.

### 5.3 Streaming and event mode:

Streaming mode is the default. Event mode is enabled by setting bit 5 in the <u>General System Settings (0xD0)</u> register.

#### 5.3.1 Streaming mode

The ready is triggered every cycle and per the report rate.

#### 5.3.2 Event mode

The ready is triggered only when an event has occurred.

The events which trigger the ready can be configured to:

- Hall wheel movement (If the hall UI is enabled)
- Touch or proximity events on channel 0 or 1
- Interval Event<sup>1</sup>

Note: Both these events have built in hysteresis which filters out very slow changes.

<sup>&</sup>lt;sup>1</sup> Only available on IQS624-32





### 5.4 Report rates

### 5.4.1 Normal Power Maximum Report rate

Note: Assuming normal mode report rate set to 0 (maximum speed) and Auto Power Modes turned off.

| Hall UI<br>State | Channels             | Register Address                        | Bytes | Functionality <sup>1</sup>                                        | Report Rate <sup>2</sup> |
|------------------|----------------------|-----------------------------------------|-------|-------------------------------------------------------------------|--------------------------|
| On               | 2 x Prox<br>4 x Hall | 0x02 (PXS Flags)<br>0x80-0x81 (Degrees) | 3     | On-chip calculation of rotation angle and prox channels.          | 4.87 ms                  |
| On               | 4 x Hall             | 0x80-0x81 (Degrees)                     | 2     | On-chip calculation of rotation angle.                            | 3.29 ms                  |
| Off              | 2 x Prox<br>4 x Hall | 0x02 (PXS Flags)<br>0x24-0x2B (Counts)  | 9     | Off-chip calculation of rotation angle and on-chip prox channels. | 3.93 ms                  |
| Off              | 4 x Hall             | 0x24-0x2B (Counts)                      | 8     | Off-chip calculation of rotation angle.                           | 2.94 ms                  |
| Off              | 1 x Hall<br>2 x Prox | 0x24 (CH2 Counts)<br>0x02 (PXS Flags)   | 3     | Off-chip RPM-calculation and 2 Prox channels on-chip              | 2.25 ms                  |
| Off              | 1 x Hall<br>1 x Prox | 0x24 (CH2 Counts)<br>0x02 (PXS Flags)   | 3     | Off-chip RPM-calculation and 1 Prox channels on-<br>chip          | 1.63 ms                  |
| Off              | 1 x Hall             | 0x24 (CH2 Counts)                       | 2     | Off-chip RPM-calculation                                          | 0.82 ms                  |

Report rates are not necessarily an accurate indication of maximum observable rotation rate. On-chip calculations are only accurate at low rotation rates.

- (1) Contact Azoteq for further information on functionality.
- (2) These values were calculated by design and not by testing.

## 5.5 System reset

The IQS624 device monitor's system resets and events.

- a) Every device power-on and reset event will set the Show Reset bit in the <u>System Flags</u> (0x10; bit 7) register and the master should explicitly clear this bit by setting the Ack Reset bit in the <u>General System Settings (0xD0; bit 6)</u> register.
- b) The system events will also be indicated with the Event bit in the <u>System Flags (0x10; bit 1)</u> register if any system event occur such as a reset. This event will continuously trigger until the reset has been acknowledged.





### 6. Communication

The **IQS624** device interfaces to a master controller via a 3-wire (SDA, SCL and RDY) serial interface bus that is I<sup>2</sup>C<sup>TM</sup> compatible with a maximum communication speed of 400 kHz. The communications interface of the IQS624 supports the following:

- Streaming data as well as event mode.
- The master may address the device at any time. If the IQS624 is not in a communication window, the device returns an ACK after which clock stretching is induced until a communication window is entered. Additional communication checks are included in the main loop in order to reduce the average clock stretching time.
- The provided interrupt line (RDY) is push-pull active low on IQS624-3001 and open-drain active low on IQS624-32. The RDY indicates a communication window.

### 6.1 Control Byte

The Control byte indicates the 7-bit device address (44H default) and the Read/Write indicator bit. The structure of the control byte is shown in Figure 6-1.



Figure 6-1 IQS624 Control Byte

The I<sup>2</sup>C device has a 7 bit Slave Address (default 0x44H) in the control byte. To confirm the address, the software compares the received address with the device address. Sub-address values can be set by OTP programming options.

#### **6.2 I2C Read**

To read from the device a *current address read* can be performed. This assumes that the address-command is already setup as desired.

#### Current Address Read

| Start | Control Byte |     | Data n |     | Data n+1 |      | Stop |  |
|-------|--------------|-----|--------|-----|----------|------|------|--|
| S     |              | ACK |        | ACK |          | NACK | S    |  |

Figure 6-2 Current Address Read

If the address-command must first be specified, then a *random read* must be performed. In this case a WRITE is initially performed to setup the address-command, and then a repeated start is used to initiate the READ section.



Figure 6-3 Random Read





#### 6.3 I2C Write

To write settings to the device a *Data Write* is performed. Here the Address-Command is always required, followed by the relevant data bytes to write to the device.

#### **DATA WRITE**

| Start Control Byte |             | Command | <b>5</b> . |     |  | Data n+1 |  |     |   |  |
|--------------------|-------------|---------|------------|-----|--|----------|--|-----|---|--|
| S                  | Adr + WRITE | ACK     |            | ACK |  | ACK      |  | ACK | S |  |

Figure 6-4 I<sup>2</sup>C Write

#### 6.4 End of Communication Session / Window

Similar to other Azoteq I<sup>2</sup>C devices, to end the I<sup>2</sup>C communication session, a STOP command is given. When sending numerous read and write commands in one communication cycle, a repeated start command must be used to stack them together (since a STOP will jump out of the communication window, which is not desired).

The STOP will then end the communication, and the **IQS624** will return to process a new set of data. Once this is obtained, the communication window will again become available (RDY set LOW).

### 6.5 Stop-bit disable option(IQS624-32)

The IQS624-32 part offer:

- an additional <a href="I2C settings">I2C settings</a> register (0xD9) specifically added for stop-bit disable functionality,
- as well as a <u>RDY timeout period</u> register (0xD8) in order to set the required timeout period for termination of any communication windows (RDY = Low) if no I<sup>2</sup>C activity is present on SDA and SCL pins.

Customers using an MCU with a binary serial-encoder peripheral which is not fully I<sup>2</sup>C compatible (but provide some crude serial communication functions) can use this option to configure the IQS624-32 so that any auto generated stop command from the serial peripheral can be ignored by the IQS624-32 I<sup>2</sup>C hardware. This will restrict the IQS624-32 from immediately exiting a communication window during event mode (reduced communication only for events) until all required communication has been completed and a stop command can correctly be transmitted. Please refer to the figures below for serial data transmission examples.

#### Please note:

- 1. Stop-bit disable and enable must be performed at the beginning and end of a communication window. The first and last I<sup>2</sup>C register to be written to ensure no unwanted communication window termination.
- 2. Leaving the Stop-bit disabled will result in successful reading of registers but will not execute any commands written over I2C in a communication window being terminated after a RDY timeout and with no IQS recognised stop command.
- 3. The default RDY timeout period for IQS624-32 is purposefully long (10.24ms) for slow responding MCU hardware architectures. Please set this register according to your requirements/preference.
- 4. These options are only available on IQS624-32 parts and not for IQS624-3001.





#### **Stop-bit Disable**

| Communication window open | Start | art Control byte |     | Address-<br>Command |     | Disable<br>stop-bit |     | Ignored stop | Continue with reads / writes |
|---------------------------|-------|------------------|-----|---------------------|-----|---------------------|-----|--------------|------------------------------|
| RDY = ↓LOW                | S     | Addr + WRITE     | ACK | 0xD9                | ACK | 0x81                | ACK | 8            |                              |

Figure 6-5 I<sup>2</sup>C Stop-bit Disable

#### **Stop-bit Enable**

| Reads / Writes<br>Finished | Start | Control byte |     | Address-<br>Command |     | Enable<br>stop-bit |     | Stop | Communication window closed |
|----------------------------|-------|--------------|-----|---------------------|-----|--------------------|-----|------|-----------------------------|
|                            | S     | Addr + WRITE | ACK | 0xD9                | ACK | 0x01               | ACK | S    | RDY = ↑HIGH                 |

Figure 6-6 I<sup>2</sup>C Stop-bit Enable

#### 6.6 Device address and sub-addresses

The default device address is **0x44 = DEFAULT\_ADDR**.

Alternative sub-address options are definable in the following one-time programmable bits: OTP Bank0 (bit3; 0; bit1; bit0) = SUB\_ADDR\_0 to SUB\_ADDR\_7

0x44 = DEFAULT ADDR OR SUB ADDR 0 a) Default address: b) Sub-address: 0x45 = DEFAULT ADDR OR SUB ADDR 1 c) Sub-address: 0x46 = DEFAULT\_ADDR OR SUB\_ADDR\_2 d) Sub-address: 0x47 = DEFAULT ADDR OR SUB ADDR 3 e) Sub-address: 0x4C = DEFAULT\_ADDR OR SUB\_ADDR\_4 f) Sub-address: 0x4D = DEFAULT\_ADDR OR SUB\_ADDR\_5 g) Sub-address: 0x4E = DEFAULT\_ADDR OR SUB\_ADDR\_6 h) Sub-address: 0x4F = DEFAULT\_ADDR OR SUB\_ADDR\_7

## 6.7 Additional OTP options

All one-time-programmable device options are located in FG bank 0.

|            | Floating Gate Bank0 |           |   |   |                  |      |                 |   |  |  |  |  |  |
|------------|---------------------|-----------|---|---|------------------|------|-----------------|---|--|--|--|--|--|
| Bit Number | 7                   | 6         | 5 | 4 | 3                | 2    | 1               | 0 |  |  |  |  |  |
| Name       | ı                   | Comms ATI | 1 | 1 | Sub address<br>2 | 8MHz | Sub address 0-1 |   |  |  |  |  |  |
| Default    | -                   | 0         | - | 0 | 0                | 0    | 0               | 0 |  |  |  |  |  |

#### Bit definitions:

- Bit 6: Comms mode during ATI
  - o 0: No streaming events are generated during ATI
  - 1: Comms continue as setup regardless of ATI state.
- Bit 2: Main Clock frequency selection
  - 0: Run FOSC at 16MHz
  - 1: Run FOSC at 8MHz
- Bit 0,1,3: I2C sub-address
  - I2C address = 0x44





All calibration data are located in FG bank 3 for the latest IQS624-3001 and all IQS624-32 IC's.

|            | Floating Gate Bank3 |   |   |   |                             |   |   |   |  |  |  |
|------------|---------------------|---|---|---|-----------------------------|---|---|---|--|--|--|
| Bit Number | 7                   | 6 | 5 | 4 | 3                           | 2 | 1 | 0 |  |  |  |
| Name       |                     | - |   |   | Hall Plate Calibration Data |   |   |   |  |  |  |
| Default    |                     | - |   |   | 15-1                        |   |   |   |  |  |  |

#### Bit definitions:

- Bit 3-0: Hall Plate Calibration Data
  - 15-1: The calibration bin of the IC
  - o 0: The IC is not calibrated (Before June 2018)

Please refer to Appendix B: Magnet calibration for information regarding hall plate calibration.

### 6.8 Request Communication Window

The master or host MCU has the capability to request a communication window at any time, by writing the device address to the IQS624. The communication window will open directly following the current conversion cycle.

### 6.9 I<sup>2</sup>C Specific Commands

#### 6.3.1 Show Reset

After start-up, and after every reset event, the "Show Reset" flag will be set in the <u>System Flags</u> register (0x10H; bit 7).

The "Show Reset" bit can be read to determine whether a reset has occurred on the device (it is recommended to be continuously monitored). This bit will be set '1' after a reset.

The "Show Reset" flag will be cleared (set to '0') by writing a '1' into the "Ack reset" bit in the <u>General system settings register (0xD0; bit 6)</u>. A reset will typically take place if a timeout during communication occurs.

#### 6.3.2 I2C Timeout

If no communication is initiated from the master/host MCU within the first  $t_{COMMS}$  ( $t_{COMMS}$  = 2.038 ms default) of the RDY line indicating that data is available (i.e. RDY = low), the device will resume with the next cycle of charge transfers and the data from the previous conversions will be lost. The RDY timeout period register (0xD8) can be adjusted on IQS624-32. There is also a timeout ( $t_{I2C}$ ) that cannot be disabled, for when communication has started but not been completed, for example when the bus is being held by another device ( $t_{I2C}$  = 33 ms).





## 6.10 Recommended communication and runtime flow diagram

The following is a basic master program flow diagram to communicate and handle the device. It addresses possible device events such as output events, ATI and system events (resets).



Figure 6-7 Master command structure and runtime event handling flow diagram

It is recommended that the master verifies the status of the <u>System Flags (0x10)</u> bits to identify events and resets. Detecting either one of these should prompt the master to the next steps of handling the IQS624.

Streaming mode communication is used for detail sensor evaluation during prototyping and/or development phases. Event mode communication is recommended for runtime use of the IQS624.





## 7. IQS624 Memory map

Table 7-1 IQS624 Register map

| Register Address | Group                              | Register Name                      |
|------------------|------------------------------------|------------------------------------|
| 0x00             |                                    | Product Number                     |
| 0x01             | <u>Device</u><br>Information       | Software Number                    |
| 0x02             | momaton                            | Hardware Number                    |
| 0x10             |                                    | System Flags                       |
| 0x12             |                                    | Proximity/Touch UI Flags           |
| 0x14             |                                    | <u>HALL UI Flags</u>               |
| 0x15             | <u>Device Specific</u> <u>Data</u> | Hall Ratio Flags                   |
| 0x16 (IQS624-32) | <u> </u>                           | Filtered Degree Output (Low byte)  |
| 0x17 (IQS624-32) | _                                  | Filtered Degree Output (High byte) |
| 0x18 (IQS624-32) |                                    | Interval Number Output             |
| 0x20             |                                    | CH0 CS Low                         |
| 0x21             | _                                  | CH0 CS High                        |
| 0x22             |                                    | CH1 CS Low                         |
| 0x23             |                                    | CH1 CS High                        |
| 0x24             |                                    | CH2 CS Low                         |
| 0x25             | _                                  | CH2 CS High                        |
| 0x26             | _                                  | CH3 CS Low                         |
| 0x27             | Count Data                         | CH3 CS High                        |
| 0x28             | Count Data                         | CH4 CS Low                         |
| 0x29             | _                                  | CH4 CS High                        |
| 0x2A             | _                                  | CH5 CS Low                         |
| 0x2B             |                                    | CH5 CS High                        |
| 0x30             |                                    | CH0 LTA Low                        |
| 0x31             |                                    | CH0 LTA High                       |
| 0x32             |                                    | CH1 LTA Low                        |
| 0x33             |                                    | CH1 LTA High                       |
| 0x40             |                                    | Ch0 ProxFusion Settings 0          |
| 0x41             | _                                  | Ch1 ProxFusion Settings 0          |
| 0x42             | Danie Translava                    | Ch0&1 ProxFusion Settings 1        |
| 0x43             | ProxFusion<br>sensor settings      | Ch0 ProxFusion Settings 2          |
| 0x44             |                                    | Ch1 ProxFusion Settings 2          |
| 0x45             |                                    | Ch0&1 ProxFusion Settings 3        |
| 0x46             |                                    | Ch0 Compensation                   |





|                  | -                             |                                        |  |  |  |  |  |
|------------------|-------------------------------|----------------------------------------|--|--|--|--|--|
| 0x47             |                               | Ch1 Compensation                       |  |  |  |  |  |
| Register Address | Group                         | Register Name                          |  |  |  |  |  |
| 0x48             | <u>ProxFusion</u>             | Ch0 Multipliers                        |  |  |  |  |  |
| 0x49             | sensor settings               | Ch1 Multipliers                        |  |  |  |  |  |
| 0x50             |                               | Ch0 Proximity threshold                |  |  |  |  |  |
| 0x51             |                               | Ch0 Touch threshold                    |  |  |  |  |  |
| 0x52             | Touch / Proximity UI settings | Ch1 Proximity threshold                |  |  |  |  |  |
| 0x53             | <u> </u>                      | Ch1 Touch threshold                    |  |  |  |  |  |
| 0x54             |                               | <u>UI Halt period</u>                  |  |  |  |  |  |
| 0x70             |                               | Hall Rotation UI Settings              |  |  |  |  |  |
| 0x71             |                               | Hall Sensor Settings                   |  |  |  |  |  |
| 0x72             |                               | Ch2&3 Hall ATI Settings                |  |  |  |  |  |
| 0x73             |                               | Ch4&5 Hall ATI Settings                |  |  |  |  |  |
| 0x74             |                               | Ch2&3 Compensation                     |  |  |  |  |  |
| 0x75             |                               | Ch4&5 Compensation                     |  |  |  |  |  |
| 0x76             |                               | Ch2&3 Multipliers                      |  |  |  |  |  |
| 0x77             | HALL Sensor                   | Ch4&5 Multipliers                      |  |  |  |  |  |
| 0x78             | Settings                      | Hall Ratio Settings                    |  |  |  |  |  |
| 0x79             |                               | Sin Constant                           |  |  |  |  |  |
| 0x7A             |                               | Cos Constant                           |  |  |  |  |  |
| 0x7B (IQS624-32) |                               | Wheel Filter Beta                      |  |  |  |  |  |
| 0x7C (IQS624-32) |                               | Wheel Wake Preload                     |  |  |  |  |  |
| 0x7D (IQS624-32) |                               | Interval UI Divider                    |  |  |  |  |  |
| 0x7E (IQS624-32) |                               | Wheel Offset (Low byte)                |  |  |  |  |  |
| 0x7F (IQS624-32) |                               | Wheel Offset (High byte)               |  |  |  |  |  |
| 0x80             |                               | Degree Output (Low byte)               |  |  |  |  |  |
| 0x81             |                               | Degree Output (High byte)              |  |  |  |  |  |
| 0x82             |                               | Ratio Output (Low byte)                |  |  |  |  |  |
| 0x83             |                               | Ratio Output (High byte)               |  |  |  |  |  |
| 0x84             |                               | Numerator of Ratio (Low byte)          |  |  |  |  |  |
| 0x85             | HALL Wheel<br>Output          | Numerator of Ratio (High byte)         |  |  |  |  |  |
| 0x86             | <u>-</u>                      | Denominator of Ratio (Low byte)        |  |  |  |  |  |
| 0x87             |                               | Denominator of Ratio (High byte)       |  |  |  |  |  |
| 0x88             |                               | Rotation Correction factor (Low byte)  |  |  |  |  |  |
| 0x89             |                               | Rotation Correction factor (High byte) |  |  |  |  |  |
| 0x8A             |                               | Max Numerator of Ratio (Low byte)      |  |  |  |  |  |





| 0x8B             |                      | Max Numerator of Ratio (High byte)   |  |  |  |  |  |
|------------------|----------------------|--------------------------------------|--|--|--|--|--|
| 0x8C             |                      | Max Denominator of Ratio (Low byte)  |  |  |  |  |  |
| Register Address | Group                | Register Name                        |  |  |  |  |  |
| 0x8D             |                      | Max Denominator of Ratio (High byte) |  |  |  |  |  |
| 0x8E             | HALL Wheel<br>Output | Relative Rotation Angle              |  |  |  |  |  |
| 0x8F             | <u>Output</u>        | Movement counter/timer               |  |  |  |  |  |
| 0xD0             |                      | General System Settings              |  |  |  |  |  |
| 0xD1             |                      | Active Channels                      |  |  |  |  |  |
| 0xD2             |                      | Power Mode Settings                  |  |  |  |  |  |
| 0xD3             | Device and Power     | Normal mode report rate              |  |  |  |  |  |
| 0xD4             | mode mode            | Low power mode report rate           |  |  |  |  |  |
| 0xD5             | <u>Settings</u>      | Ultra-low power mode report rate     |  |  |  |  |  |
| 0xD6             |                      | Auto Mode time                       |  |  |  |  |  |
| 0xD8 (IQS624-32) |                      | RDY Timeout Period                   |  |  |  |  |  |
| 0xD9 (IQS624-32) |                      | I2C Settings                         |  |  |  |  |  |





#### 7.1 Device Information

#### 7.1.1 Product Number

|             | Product Number (0x00) |                       |   |   |   |   |   |   |  |  |  |
|-------------|-----------------------|-----------------------|---|---|---|---|---|---|--|--|--|
| Bit Number  | 7                     | 6                     | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Data Access |                       | Read                  |   |   |   |   |   |   |  |  |  |
| Name        |                       | Device Product Number |   |   |   |   |   |   |  |  |  |

#### Bit definitions:

• Bit 0-7: Device Product Number = D'67'

#### 7.1.2 Software Number

|             |                             |   | Softwa | are Numbe | er (0x01) |   |   |   |  |  |  |
|-------------|-----------------------------|---|--------|-----------|-----------|---|---|---|--|--|--|
| Bit Number  | 7                           | 6 | 5      | 4         | 3         | 2 | 1 | 0 |  |  |  |
| Data Access |                             |   |        | Re        | ad        |   |   |   |  |  |  |
| Name        | Name Device Software Number |   |        |           |           |   |   |   |  |  |  |

#### Bit definitions:

- Bit 0-7: IQS624-3yy1 Device Software Number = D'02'
- Bit 0-7: IQS624-3yy2 Device Software Number = D'11' (Backwards compatible)
- Bit 0-7: IQS624-5yy1 Device Software Number = D'02'

#### 7.1.3 Hardware Number

|             |                             |                 | Hardw | are Numb | er (0x02) |  |  |  |  |  |  |  |  |
|-------------|-----------------------------|-----------------|-------|----------|-----------|--|--|--|--|--|--|--|--|
| Bit Number  | 7                           | 7 6 5 4 3 2 1 0 |       |          |           |  |  |  |  |  |  |  |  |
| Data Access |                             |                 |       | Re       | ad        |  |  |  |  |  |  |  |  |
| Name        | Name Device Hardware Number |                 |       |          |           |  |  |  |  |  |  |  |  |

#### Bit definitions:

• Bit 0-7: Device Hardware Number = D'162' for 5V solution, D'130' for 3.3V solution





### 7.2 Device Specific Data

#### 7.2.1 System Flags

|             |       |   | Sys | tem flags   | (0x10)     |      |       |                |  |  |  |  |  |
|-------------|-------|---|-----|-------------|------------|------|-------|----------------|--|--|--|--|--|
| Bit Number  | 7     | 6 | 5   | 4           | 3          | 2    | 1     | 0              |  |  |  |  |  |
| Data Access | Read  |   |     |             |            |      |       |                |  |  |  |  |  |
| Name        | Show  |   |     | Cur         | rent       | ATI  | Event | <u>NP</u>      |  |  |  |  |  |
|             | Reset |   |     | <u>00</u> 0 | <u>wer</u> | Busy |       | <u>Segment</u> |  |  |  |  |  |
|             |       |   |     | <u>mc</u>   | <u>ode</u> |      |       | <u>Active</u>  |  |  |  |  |  |

#### Bit definitions:

- Bit 7: Reset Indicator:
  - o 0: No reset event
  - 1: A device reset has occurred and needs to be acknowledged
- Bit 4-3: Current power mode indicator:
  - o 00: Normal power mode
  - o 01: Low power mode
  - o 10: Ultra-Low power mode
  - o 11: Halt power mode
- Bit 2: ATI Busy Indicator:
  - o 0: No channels are in ATI
  - 1: One or more channels are in ATI
- Bit 1: Global Event Indicator:
  - 0: No new event to service
  - o 1: An event has occurred and should be handled
- Bit 0: Normal Power segment indicator:
  - o 0: Not performing a normal power update
  - 1: Busy performing a normal power update

#### 7.2.2 Proximity/Touch UI Flags

|             |   |   | Proximity       | /Touch U     | I Flags (0 | x12) |                  |                  |
|-------------|---|---|-----------------|--------------|------------|------|------------------|------------------|
| Bit Number  | 7 | 6 | 5               | 4            | 3          | 2    | 1                | 0                |
| Data Access |   |   |                 | R            | ead        |      |                  |                  |
| Name        |   |   | Chan 1<br>Touch | Chan 0 touch |            |      | Chan 1 proximity | Chan 0 proximity |
|             |   |   | out             | out          |            |      | out              | out              |

#### Bit definitions:

- Bit 5: Channel 1 touch indicator:
  - o 0: Channel 1 delta below touch threshold
  - o 1: Channel 1 delta above touch threshold
- Bit 4: Channel 0 touch indicator:
  - o 0: Channel 0 delta below touch threshold
  - 1: Channel 0 delta above touch threshold
- Bit 1: Channel 1 Proximity indicator:
  - o 0: Channel 1 delta below proximity threshold
  - 1: Channel 1 delta above proximity threshold
- Bit 0: Channel 0 Proximity indicator:
  - o 0: Channel 0 delta below proximity threshold
  - o 1: Channel 0 delta above proximity threshold





#### 7.2.3 Hall UI Flags

|             |          |                  | Hall UI | Flags (0 | x14) |   |   |   |  |  |  |  |  |  |  |
|-------------|----------|------------------|---------|----------|------|---|---|---|--|--|--|--|--|--|--|
| Bit Number  | 7        | 6                | 5       | 4        | 3    | 2 | 1 | 0 |  |  |  |  |  |  |  |
| Data Access |          | Read             |         |          |      |   |   |   |  |  |  |  |  |  |  |
| Name        | Wheel    | Movement         |         |          |      |   |   |   |  |  |  |  |  |  |  |
|             | movement | <u>direction</u> |         |          |      |   |   |   |  |  |  |  |  |  |  |

#### Bit definitions:

- Bit 7: Wheel movement indicator:
  - o 0: No wheel movement detected
  - 1: Wheel movement detected
- Bit 6: Movement direction indicator:
  - o 0: If movement is detected it is in positive direction
  - o 1: If movement is detected it is in negative direction

#### 7.2.4 Hall Ratio Flags

|             |   |   | Н | all Ratio | Flags (0 | x15)    |             |           |
|-------------|---|---|---|-----------|----------|---------|-------------|-----------|
| Bit Number  | 7 | 6 | 5 | 4         | 3        | 2       | 1           | 0         |
| Data Access |   |   |   |           | Read     |         |             |           |
| Name        |   |   |   |           |          | Move    | Max         | Max       |
|             |   |   |   |           |          | counter | Denominator | Numerator |
|             |   |   |   |           |          | full    | set         | set       |

#### Bit definitions:

- Bit 2: Move counter full indicator:
  - o 0: Movement counter is not full
  - o 1: Movement counter is full
- Bit 1: Max Denominator set indicator:
  - o 0: Max denominator has not changed
  - o 1: Max denominator has changed (used for auto calibration)
- Bit 0: Max Numerator set indicator:
  - o 0: Max Numerator has not changed
  - o 1: Max Numerator has changed (used for auto calibration)

#### 7.2.5 Filtered Degree Output<sup>1</sup>

|             |                                                         |  |  | Fil | terec | l Deg | ree C | Outpu | ıt¹ (0x | <b>k17-0</b> | x16) |  |   |  |  |
|-------------|---------------------------------------------------------|--|--|-----|-------|-------|-------|-------|---------|--------------|------|--|---|--|--|
| Bit Number  | <b>Bit Number</b> 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |     |       |       |       |       |         |              |      |  | 0 |  |  |
| Data Access |                                                         |  |  |     |       |       |       | Re    | ad      |              |      |  |   |  |  |
| Name        | Name Degrees High Byte Degrees Low Byte                 |  |  |     |       |       |       |       |         |              |      |  |   |  |  |

#### Bit definitions:

• 0-360: Filtered absolute degree position of magnet

-

<sup>&</sup>lt;sup>1</sup> Only available on IQS624-32





#### 7.2.6 Interval Number<sup>1</sup>

|             |                              |   | Interv | al Numbe | r <sup>1</sup> (0x18) |   |   |   |  |  |  |
|-------------|------------------------------|---|--------|----------|-----------------------|---|---|---|--|--|--|
| Bit Number  | 7                            | 6 | 5      | 4        | 3                     | 2 | 1 | 0 |  |  |  |
| Data Access |                              |   |        | Read     | /Write                |   |   |   |  |  |  |
| Name        | Name Current Interval Number |   |        |          |                       |   |   |   |  |  |  |

• Bit 7-0: Current interval number

### 7.3 Count Data

#### 7.3.1 Count CS Values

|             |                                                                                  |  |    | Cou   | nt CS | valu | es (0 | x20/0 | )x21- | 0x2A | /0x2E | 3)    |      |     |  |
|-------------|----------------------------------------------------------------------------------|--|----|-------|-------|------|-------|-------|-------|------|-------|-------|------|-----|--|
| Bit Number  | Bit Number   15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |  |    |       |       |      |       |       |       |      |       |       |      |     |  |
| Data Access |                                                                                  |  |    |       |       |      |       | Re    | ad    |      |       |       |      |     |  |
| Name        |                                                                                  |  | Со | unt H | igh B | yte  |       |       |       |      | Co    | unt L | ow B | yte |  |

#### Bit definitions:

- Bit 15-0: Counts
  - o AC filter or raw value

#### 7.3.2 LTA Values

|             |                                                                     |  |  | L | TA va | alues | (0x3 | 0/0x3 | 31-0x | 32/0x | 33) |  |  |  |
|-------------|---------------------------------------------------------------------|--|--|---|-------|-------|------|-------|-------|-------|-----|--|--|--|
| Bit Number  | 15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |  |  |   |       |       |      |       |       |       |     |  |  |  |
| Data Access |                                                                     |  |  |   |       |       |      | Re    | ad    |       |     |  |  |  |
| Name        | LTA High Byte LTA Low Byte                                          |  |  |   |       |       |      |       |       |       |     |  |  |  |

#### Bit definitions:

- Bit 15-0: LTA Values
  - o LTA filter value





### 7.4 ProxFusion sensor settings

### 7.4.1 Ch0/1 ProxFusion Settings 0

#### **Capacitive Sensing**

|             |                 | Ch0/      | 1 ProxFu | sion Setting | gs 0 (0x40 | /0x41) |     |        |  |  |  |  |  |  |
|-------------|-----------------|-----------|----------|--------------|------------|--------|-----|--------|--|--|--|--|--|--|
| Bit Number  | 7 6 5 4 3 2 1 0 |           |          |              |            |        |     |        |  |  |  |  |  |  |
| Data Access | Read/Write      |           |          |              |            |        |     |        |  |  |  |  |  |  |
| Name        |                 | Senso     | r mode   |              | TX s       | elect  | RXs | select |  |  |  |  |  |  |
| Default     | 0               | 0 0 0 0 0 |          |              |            |        |     |        |  |  |  |  |  |  |

#### Bit definitions:

• Bit 7-4: Sensor mode select:

o 0000: Self capacitive mode

• Bit 3-2:TX-select:

o 00: TX 0 and TX 1 is disabled

• Bit 1-0: RX select:

o 00: RX 0 and RX 1 is disabled

01: RX 0 is enabled10: RX 1 is enabled

o 11: RX 0 and RX 1 is enabled

#### **Inductive Sensing**

|             |   | Ch0/            | 1 ProxFu | sion Setting | gs 0 (0x40 | /0x41) |      |       |  |  |  |  |  |  |
|-------------|---|-----------------|----------|--------------|------------|--------|------|-------|--|--|--|--|--|--|
| Bit Number  | 7 | 6               | 5        | 4            | 3          | 2      | 1    | 0     |  |  |  |  |  |  |
| Data Access |   | Read/Write      |          |              |            |        |      |       |  |  |  |  |  |  |
| Name        |   | Senso           | r mode   |              | TX s       | elect  | RX s | elect |  |  |  |  |  |  |
| Default     | 1 | 1 0 0 1 0 0 1 1 |          |              |            |        |      |       |  |  |  |  |  |  |

#### Bit definitions:

• Bit 7-4: Sensor mode select:

o 1001: Mutual Inductive mode

Bit 3-2:TX-select:

o 00: TX 0 and TX 1 is disabled

• Bit 1-0: RX select:

o 11: RX 0 and RX 1 is enabled

#### 7.4.2 Ch0&1 ProxFusion Settings 1

| Ch0&1 ProxFusion Settings 1 (0x42) |            |           |             |   |               |   |               |   |
|------------------------------------|------------|-----------|-------------|---|---------------|---|---------------|---|
| Bit Number                         | 7          | 6         | 5           | 4 | 3             | 2 | 1             | 0 |
| Data Access                        | Read/Write |           |             |   |               |   |               |   |
| Name                               | -          | CS<br>PXS | Charge Freq |   | Proj bias pxs |   | Auto ATI Mode |   |
| Default                            | 0x5B       |           |             |   |               |   |               |   |

#### Bit definitions:

• Bit 6: ProxFusion Sensing Capacitor size select:

o 0: ProxFusion Sensing capacitor size is 15 pF

o 1: ProxFusion Sensing capacitor size is 60 pF

Bit 5-4: Charge Frequency select:





- 00: 1/2
- 01: 1/4
- o 10: 1/8
- 0 11: 1/16
- Bit 3-2: Projected bias:
  - $\circ$  00: 2.5μA / 88kΩ
  - 01: 5μA / 66kΩ
  - $\circ$  10: 10 $\mu$ A / 44 $k\Omega$
  - o 11: 20μA / 22kΩ
- Bit 1-0: Auto ATI Mode select:
  - o 00: ATI Disabled
  - o 01: Partial ATI (Multipliers are fixed)
  - o 10: Semi Partial ATI (Coarse multipliers are fixed)
  - o 11: Full ATI

## 7.4.3 Ch0 ProxFusion Settings 2

|             | Ch0 ProxFusion Settings 2 (0x43) |            |   |   |                  |        |   |   |  |  |  |
|-------------|----------------------------------|------------|---|---|------------------|--------|---|---|--|--|--|
| Bit Number  | 7                                | 6          | 5 | 4 | 3                | 2      | 1 | 0 |  |  |  |
| Data Access |                                  | Read/Write |   |   |                  |        |   |   |  |  |  |
| Name        | ATI E                            | Base       |   |   | ATI <sup>-</sup> | Target |   |   |  |  |  |
| Default     |                                  | 0x50       |   |   |                  |        |   |   |  |  |  |

#### Bit definitions:

- Bit 7-6: ATI Base value select:
  - 00:75
  - 01:100
  - o 10: 150
  - o 11: 200
- Bit 5-0: ATI Target:
  - o ATI Target is 6-bit value x 32

## 7.4.4 Ch1 ProxFusion Settings 2

|             | Ch1 ProxFusion Settings 2 (0x44) |            |   |   |       |        |   |   |  |  |  |
|-------------|----------------------------------|------------|---|---|-------|--------|---|---|--|--|--|
| Bit Number  | 7                                | 6          | 5 | 4 | 3     | 2      | 1 | 0 |  |  |  |
| Data Access |                                  | Read/Write |   |   |       |        |   |   |  |  |  |
| Name        | ATI E                            | Base       |   |   | ATI 7 | Target |   |   |  |  |  |
| Default     |                                  | 0x50       |   |   |       |        |   |   |  |  |  |

### Bit definitions:

- Bit 7-6: ATI Base value select:
  - 00:75
  - 01:100
  - 0 10:150
  - o 11: 200
- Bit 5-0: ATI Target:
  - o ATI Target is 6-bit value x 32





## 7.4.5 Ch0&1 ProxFusion Settings 3

|             | Ch0&1 ProxFusion Settings 3 (0x45) |                 |                     |                |     |      |     |      |  |  |  |  |
|-------------|------------------------------------|-----------------|---------------------|----------------|-----|------|-----|------|--|--|--|--|
| Bit Number  | 7                                  | 7 6 5 4 3 2 1 0 |                     |                |     |      |     |      |  |  |  |  |
| Data Access |                                    | Read/Write      |                     |                |     |      |     |      |  |  |  |  |
| Name        | -                                  | CS Div          | Two<br>sided<br>PXS | ACF<br>Disable | LTA | Beta | ACF | Beta |  |  |  |  |
| Default     | 0x00                               |                 |                     |                |     |      |     |      |  |  |  |  |

#### Bit definitions:

- Bit 6: CS divider
  - o 0: Sampling capacitor divider disabled
  - o 1: Sampling capacitor divider enabled
- Bit 5: Two sided ProxFusion Sensing
  - 0: Bidirectional detection disabled
  - 1: Bidirectional detection enabled
- Bit 4: ACF Disable
  - o 0: AC Filter Enabled
  - o 1: AC Filter Disabled
- Bit 3-2:LTA Beta 0
  - 00: 7
  - 0 01: 8
  - 0 10: 9
  - o 11: 10
- Bit 1-0: ACF Beta 1
  - 00:1
  - 01:2
  - 0 10:3
  - o 11:4

## 7.4.6 Ch0/Ch1 Compensation

|                         | Ch0/Ch1 Compensation (0x46,0x47) |            |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------|------------|--|--|--|--|--|--|--|--|
| Bit Number              | 7 6 5 4 3 2 1 0                  |            |  |  |  |  |  |  |  |  |
| Data Access             |                                  | Read/Write |  |  |  |  |  |  |  |  |
| Name Compensation (7-0) |                                  |            |  |  |  |  |  |  |  |  |

#### Bit definitions:

• Bit 7-0:0-255: Lower 8 bits of the Compensation Value

### Register addresses:

- 0x46: Channel 0 Lower 8 bits of the Compensation Value
- 0x47: Channel 1 Lower 8 bits of the Compensation Value





## 7.4.7 Ch0/Ch1 Multipliers values

|             | Ch0/1 Multipliers values(0x48/0x49) |                                                      |  |  |  |  |  |  |  |  |  |
|-------------|-------------------------------------|------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Bit Number  | 7                                   | 7 6 5 4 3 2 1 0                                      |  |  |  |  |  |  |  |  |  |
| Data Access |                                     | Read/Write                                           |  |  |  |  |  |  |  |  |  |
| Name        | Compens                             | Compensation (9-8) Coarse multiplier Fine multiplier |  |  |  |  |  |  |  |  |  |

#### Bit definitions:

- Bit 7-6: Compensation upper two bits
  - o 0-3: Upper 2-bits of the Compensation value.
- Bit 5-4: Coarse multiplier Selection:
  - o 0-3: Coarse multiplier selection
- Bit 3-0: Fine Multiplier Selection:
  - o 0-15: Fine Multiplier selection

### Register addresses:

- 0x48: Channel 0 Multipliers Value
- 0x49: Channel 1 Multipliers Value

## 7.5 Touch / Proximity UI settings

## 7.5.1 Ch0/1 Proximity/touch threshold

| Proximity/touch threshold Ch0/1(0x50-0x53) |   |                 |  |  |  |  |  |  |  |  |  |
|--------------------------------------------|---|-----------------|--|--|--|--|--|--|--|--|--|
| Bit Number                                 | 7 | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |  |
| Data Access                                |   | Read/Write      |  |  |  |  |  |  |  |  |  |
| Name <u>Threshold</u>                      |   |                 |  |  |  |  |  |  |  |  |  |

### Bit definitions:

Bit 7-0: Proximity and touch thresholds: If a difference between the LTA and counts value would exceed this threshold the appropriate event would be flagged (either Touch or Proximity Event).

## Register addresses:

- 0x50 Channel 0 Proximity Threshold Value
- 0x51 Channel 0 Touch Threshold Value
- 0x52 Channel 1 Proximity Threshold Value
- 0x53 Channel 1 Touch Threshold Value

### 7.5.2 UI Halt period

|             | UI Halt period (0x54) |               |   |        |          |   |   |   |  |  |  |
|-------------|-----------------------|---------------|---|--------|----------|---|---|---|--|--|--|
| Bit Number  | 7                     | 6             | 5 | 4      | 3        | 2 | 1 | 0 |  |  |  |
| Data Access |                       | Read/Write    |   |        |          |   |   |   |  |  |  |
| Name        |                       |               |   | UI Hal | t period |   |   |   |  |  |  |
| Default     |                       | 0x28 = 20 sec |   |        |          |   |   |   |  |  |  |

### Bit definitions:

• Bit 7-0: Halt time in 500 ms ticks





## 7.6 HALL Sensor Settings

## 7.6.1 Hall Rotation UI Settings

|                |                             | На                                  | all Rotatio | n UI Settings | s (0x70) |   |   |   |  |  |  |
|----------------|-----------------------------|-------------------------------------|-------------|---------------|----------|---|---|---|--|--|--|
| Bit Number     | 7                           | 7 6 5 4 3 2 1 0                     |             |               |          |   |   |   |  |  |  |
| Data<br>Access |                             | Read/Write                          |             |               |          |   |   |   |  |  |  |
| Name           | Hall<br>Wheel<br>UI disable | Wheel UI Zero Event Event Auto - Wh |             |               |          |   |   |   |  |  |  |
| Default        | 0                           | 0                                   | 0           | 0             | 1        | 1 | - | 0 |  |  |  |

### Bit definitions:

• Bit 7: Hall Wheel UI disable

o 0: Hall wheel UI is enabled

o 1: Hall wheel UI is disabled

Bit 6: Interval UI disable<sup>1</sup>

o 0: Interval UI is enabled

1: Interval UI is disabled

Bit 5: Zero Wheel angle<sup>1</sup>

1: Zero angle, automatically cleared by firmware

• Bit 4: Hall Wheel UI Event disable<sup>1</sup>

o 0: Event UI is enabled

o 1: Event UI is disabled

Bit 3: Interval UI Event disable<sup>1</sup>

o 0: Event UI is enabled

o 1: Event UI is disabled

• Bit 2: Auto calibration

o 0: Auto calibration disabled

o 1: Auto calibration enabled

• Bit 0: Wheel wakeup select

o 0: Wheel wakeup mode disabled

o 1: Wheel wakeup mode enabled (wakes up on Ch0 touch).

## 7.6.2 Hall Sensor Settings

|             | Hall Sensor Settings (0x71) |                                                           |   |   |   |   |   |   |  |  |  |  |
|-------------|-----------------------------|-----------------------------------------------------------|---|---|---|---|---|---|--|--|--|--|
| Bit Number  | 7                           | 7 6 5 4 3 2 1 0                                           |   |   |   |   |   |   |  |  |  |  |
| Data Access |                             | Read/Write                                                |   |   |   |   |   |   |  |  |  |  |
| Name        | ACF Enable <sup>1</sup>     | CF Enable <sup>1</sup> - Charge Freq - Auto ATI mode Hall |   |   |   |   |   |   |  |  |  |  |
| Default     | 0                           | 0                                                         | 0 | 0 | 0 | 0 | 1 | 1 |  |  |  |  |

### Bit definitions:

Bit 7: ACF Enable: Enable filter on the individual Hall channels<sup>1</sup>

o 0: Filter disabled

1: Filter Enabled

<sup>&</sup>lt;sup>1</sup> Only available on IQS624-32





- Bit 5-4: Charge Frequency: The rate at which our measurement circuit samples
  - 00: 1/2
  - 01:1/4
  - 0 10: 1/8
  - 0 11: 1/16
- Bit 1-0: Auto ATI Mode<sup>1</sup>
  - o 00: ATI disabled: ATI is completely disabled
  - o 01: Partial ATI: Only adjusts compensation
  - o 10: Semi-Partial ATI: Only adjusts compensation and the fine multiplier.
  - o 11: Full-ATI: Compensation and both coarse and fine multipliers is adjusted

## 7.6.3 Ch2/3, Ch4/5 Hall ATI Settings<sup>2</sup>

|             | Ch2/3, Ch4/5 Hall ATI Settings (0x72/0x73) |            |   |   |     |        |   |   |  |  |  |  |
|-------------|--------------------------------------------|------------|---|---|-----|--------|---|---|--|--|--|--|
| Bit Number  | 7                                          | 6          | 5 | 4 | 3   | 2      | 1 | 0 |  |  |  |  |
| Data Access |                                            | Read/Write |   |   |     |        |   |   |  |  |  |  |
| Name        | ATI E                                      | Base       |   |   | ATI | Target |   |   |  |  |  |  |
| Default     |                                            | 0x73       |   |   |     |        |   |   |  |  |  |  |

### Register addresses:

- 0x72: Channel 2 & 3 ATI settings
- 0x73: Channel 4 & 5 ATI settings

### Bit definitions:

- Bit 7-6: ATI Base value select:
  - 00:75
  - 01:100
  - 0 10:150
  - o 11: 200
- Bit 5-0: ATI Target:
  - o ATI Target is 6-bit value x 32

## 7.6.4 Ch2/3, Ch4/5 Hall Compensation

|             | Ch2/3, Ch4/5 Hall Compensation (0x74,0x75)                                                 |  |  |  |  |  |  |  |  |  |
|-------------|--------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Bit Number  | Bit Number         7         6         5         4         3         2         1         0 |  |  |  |  |  |  |  |  |  |
| Data Access | cess Read/Write                                                                            |  |  |  |  |  |  |  |  |  |
| Name        | Name Compensation (7-0)                                                                    |  |  |  |  |  |  |  |  |  |

#### Bit definitions:

• Bit 7-0: 0-255: Lower 8 bits of the compensation value

<sup>2</sup> See Appendix B for more information

<sup>&</sup>lt;sup>1</sup> Refer to the Errata





## 7.6.5 Ch2/3, Ch4/5 Hall Multipliers

| Ch2/3, Ch4/5 Hall Multipliers (0x76-0x77) |         |                                                    |  |  |  |  |  |  |  |  |  |
|-------------------------------------------|---------|----------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Bit Number                                | 7       | 7 6 5 4 3 2 1 0                                    |  |  |  |  |  |  |  |  |  |
| Data Access                               |         | Read/Write                                         |  |  |  |  |  |  |  |  |  |
| Name                                      | Compens | Compensation 9-8 Coarse Multiplier Fine Multiplier |  |  |  |  |  |  |  |  |  |

#### Bit definitions:

- Bit 7-6: Compensation 9-8:
  - o 0-3: Upper 2-bits of the compensation value
- Bit 5-4: Coarse multiplier selection
  - o 0-3: Coarse multiplier selection
- Bit 3-0: Fine multiplier selection
  - o 0-15: Fine multiplier selection

## 7.6.6 Hall Ratio Settings

|             |   |             |               | Hall | ratio settings                        | (0x78)            |                      |                    |
|-------------|---|-------------|---------------|------|---------------------------------------|-------------------|----------------------|--------------------|
| Bit Number  | 7 | 6           | 5             | 4    | 3                                     | 2                 | 1                    | 0                  |
| Data Access |   | R           | ead           |      | Read/Write                            |                   | Read                 |                    |
| Name        | - | Octant flag | Y<br>negative | -    | Direction<br>invert / Cos<br>negative | Ratio<br>Negative | Denominator negative | Numerator negative |

#### Bit definitions:

- Bit 6-5: Quadrature output for octant changes (per 45 degrees)
  - o 0-3: Quadrature output
- Bit 3: Invert direction of degrees
  - 0 Invert not active
  - 1 Invert active
- Bit 2: Ratio negative (Used for on-chip angle calculation)
  - 0 Ratio is positive
  - 1 Ratio is negative
- Bit 1: Denominator negative (Used for on-chip angle calculation)
  - 0 Denominator is positive
  - 1 Denominator is negative
- Bit 0: Numerator negative (Used for on-chip angle calculation)
  - o 0 Numerator is positive
  - 1 Numerator is negative

#### 7.6.7 Sin Constant

|             |   |   | Sin | constant | (0x79) |   |   |   |
|-------------|---|---|-----|----------|--------|---|---|---|
| Bit Number  | 7 | 6 | 5   | 4        | 3      | 2 | 1 | 0 |
| Data Access |   |   |     | Read     | /Write |   |   |   |
| Name        |   |   |     | Sin co   | nstant |   |   |   |

#### Bit definitions:

Bit 7-0: Sin (phase difference) x 255





#### 7.6.8 Cos Constant

|             |   |   | Cos | constant | (0x7A)  |   |   |   |
|-------------|---|---|-----|----------|---------|---|---|---|
| Bit Number  | 7 | 6 | 5   | 4        | 3       | 2 | 1 | 0 |
| Data Access |   |   |     | Read     | /Write  |   |   |   |
| Name        |   |   |     | Cos co   | onstant |   |   |   |

#### Bit definitions:

• Bit 7-0: Cos (phase difference) x 255

#### Phase difference:

Phase difference measured between the signals obtained from the two Hall sensor plates. This can be calculated with a simple calibration, see <a href="Appendix B">Appendix B</a>.

#### 7.6.9 Wheel Filter Beta<sup>1</sup>

|             |   |            | Wheel | Filter Bet | a <sup>1</sup> (0x7B) |   |   |   |  |  |  |  |  |  |
|-------------|---|------------|-------|------------|-----------------------|---|---|---|--|--|--|--|--|--|
| Bit Number  | 7 | 6          | 5     | 4          | 3                     | 2 | 1 | 0 |  |  |  |  |  |  |
| Data Access |   | Read/Write |       |            |                       |   |   |   |  |  |  |  |  |  |
| Name        |   |            |       | Wheel F    | ilter Beta            |   |   |   |  |  |  |  |  |  |
| Default     | _ |            |       | 0x         | :08                   |   |   |   |  |  |  |  |  |  |

#### Bit definitions:

• Bit 7-0: Initial value used during calculation of wheel filter beta.

### 7.6.10 Wheel Wake Preload<sup>1</sup>

|             |       | W          | heel Wak | e Preload | d¹ (0x7C) |           |    |   |  |  |  |  |  |  |  |
|-------------|-------|------------|----------|-----------|-----------|-----------|----|---|--|--|--|--|--|--|--|
| Bit Number  | 7     | 6          | 5        | 4         | 3         | 2         | 1  | 0 |  |  |  |  |  |  |  |
| Data Access |       | Read/Write |          |           |           |           |    |   |  |  |  |  |  |  |  |
| Name        | Count | er Thresho | old      |           | Ti        | mer Prelo | ad |   |  |  |  |  |  |  |  |
| Default     |       | 7          |          |           |           | 31        |    |   |  |  |  |  |  |  |  |

### Bit definitions:

- Bit 7-5: Wheel Wake Counter Threshold
  - 0-7: The wheel will wake up if the counter value reaches the counter threshold value before the timer reaches 0.
- Bit 4-0: Wheel Wake Timer Preload
  - o 0: Stop timer when wheel is in sleep. Load 31 when wheel is awake.
  - 1-31: Preload Value loaded into Movement Timer (0x8F). The wheel will wake up if the Movement Counter value (0x8F) reaches the Counter Threshold value before the timer reaches 0.

\_

<sup>&</sup>lt;sup>1</sup> Only available on IQS624-32





### 7.6.11 Interval UI Divider<sup>1</sup>

|             |   |            | Interva | I UI Divide  | er¹ (0x7D)  |    |   |   |  |  |  |  |  |  |  |
|-------------|---|------------|---------|--------------|-------------|----|---|---|--|--|--|--|--|--|--|
| Bit Number  | 7 | 6          | 5       | 4            | 3           | 2  | 1 | 0 |  |  |  |  |  |  |  |
| Data Access |   | Read/Write |         |              |             |    |   |   |  |  |  |  |  |  |  |
| Name        |   |            | I.      | nterval size | e in degree | es |   |   |  |  |  |  |  |  |  |
| Default     |   |            |         | 0x           | :03         |    |   |   |  |  |  |  |  |  |  |

### Bit definitions:

• Bit 7-0: Interval size in degrees (>= 3° and <=180°)

### 7.6.12 Wheel Offset1

|             |    |      |       |       | W      | heel ( | Offse | t <sup>1</sup> (0x | 7E-0 | x7F) |       |      |        |       |   |   |
|-------------|----|------|-------|-------|--------|--------|-------|--------------------|------|------|-------|------|--------|-------|---|---|
| Bit Number  | 15 | 14   | 13    | 12    | 11     | 10     | 9     | 8                  | 7    | 6    | 5     | 4    | 3      | 2     | 1 | 0 |
| Data Access |    | Read |       |       |        |        |       |                    |      |      |       |      |        |       |   |   |
| Name        |    | V    | /heel | Offse | et Hig | h Byt  | е     |                    |      | V    | Vheel | Offs | et Lov | w Byt | е |   |
| Default     |    |      |       |       |        |        |       | 0x                 | 00   |      |       |      |        |       |   |   |

#### Bit definitions:

• 16-bit value: Wheel offset in degrees (0°- 359°)

## 7.7 Hall Wheel Output

## 7.7.1 Degree Output

|             |    |                                                                                            |     |      | De   | gree | Outp | ut (0 | x81-0 | )x80) |     |      |       |      |   |  |
|-------------|----|--------------------------------------------------------------------------------------------|-----|------|------|------|------|-------|-------|-------|-----|------|-------|------|---|--|
| Bit Number  | 15 | 14     13     12     11     10     9     8     7     6     5     4     3     2     1     0 |     |      |      |      |      |       |       |       |     |      |       |      | 0 |  |
| Data Access |    | Read                                                                                       |     |      |      |      |      |       |       |       |     |      |       |      |   |  |
| Name        |    |                                                                                            | Deg | rees | High | Byte |      |       |       |       | Deg | rees | Low I | Byte |   |  |

### Bit definitions:

• 16-bit value: Absolute degree position of magnet (0°- 359°)

## 7.7.2 Ratio Output

|             |    |                                                                                            |     |      | R    | atio ( | Outpu | ıt (0x | 83-0 | x82) |     |      |       |      |   |  |
|-------------|----|--------------------------------------------------------------------------------------------|-----|------|------|--------|-------|--------|------|------|-----|------|-------|------|---|--|
| Bit Number  | 15 | 14     13     12     11     10     9     8     7     6     5     4     3     2     1     0 |     |      |      |        |       |        |      |      |     |      |       |      | 0 |  |
| Data Access |    | Read                                                                                       |     |      |      |        |       |        |      |      |     |      |       |      |   |  |
| Name        |    |                                                                                            | Deg | rees | High | Byte   |       |        |      |      | Deg | rees | Low I | Byte |   |  |

### Bit definitions:

• 16-bit value: Ratio used to calculate degrees





### 7.7.3 Numerator

|             |    |      |      |        | 1    | Nume | rator | (0x8 | 5-0x | 84) |     |       |       |      |   |   |
|-------------|----|------|------|--------|------|------|-------|------|------|-----|-----|-------|-------|------|---|---|
| Bit Number  | 15 | 14   | 13   | 12     | 11   | 10   | 9     | 8    | 7    | 6   | 5   | 4     | 3     | 2    | 1 | 0 |
| Data Access |    | Read |      |        |      |      |       |      |      |     |     |       |       |      |   |   |
| Name        |    |      | Nume | erator | High | Byte |       |      |      |     | Num | erato | r Low | Byte |   |   |

#### Bit definitions:

• 16-bit value: Numerator used to calculate ratio

### 7.7.4 Denominator

|             |    |                                                                                            |      |        | D     | enom  | inato | or (0x | 87-0 | x86) |      |        |        |       |   |   |
|-------------|----|--------------------------------------------------------------------------------------------|------|--------|-------|-------|-------|--------|------|------|------|--------|--------|-------|---|---|
| Bit Number  | 15 | 14     13     12     11     10     9     8     7     6     5     4     3     2     1     0 |      |        |       |       |       |        |      |      |      |        |        |       |   | 0 |
| Data Access |    | Read                                                                                       |      |        |       |       |       |        |      |      |      |        |        |       |   |   |
| Name        |    | D                                                                                          | enon | ninato | r Hig | h Byt | е     |        |      |      | enor | ninato | or Lov | и Byt | е |   |

### Bit definitions:

• 16-bit value: Denominator used to calculate ratio

### 7.7.5 Rotation Correction factor

|             |    |                                                                    |      | Rot   | ation | Corr  | ectio | n fac | tor ( | 0x89-  | 0x88   | )      |       |        |      |     |
|-------------|----|--------------------------------------------------------------------|------|-------|-------|-------|-------|-------|-------|--------|--------|--------|-------|--------|------|-----|
| Bit Number  | 15 | 5   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |      |       |       |       |       |       |       |        |        |        |       |        | 0    |     |
| Data Access |    | Read                                                               |      |       |       |       |       |       |       |        |        |        |       |        |      |     |
| Name        | Ro | tatior                                                             | Corr | ectio | n Fac | tor H | igh B | yte   | Ro    | tatior | n Cori | rectio | n Fac | ctor L | ow B | yte |

### Bit definitions:

• 16-bit value: Used for auto calibration

### 7.7.6 Max Numerator

|             | Max Numerator (0x8B-0x8A) |                                                |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------|---------------------------|------------------------------------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit Number  | 15                        | 14                                             | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Data Access |                           | Read                                           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name        |                           | Max Numerator High Byte Max Numerator Low Byte |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## Bit definitions:

• 16-bit value: Used during auto calibration

### 7.7.7 Max Denominator

| Max Denominator (0x8D-0x8C) |    |                                                    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------------------------|----|----------------------------------------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit Number                  | 15 | 14                                                 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Data Access                 |    | Read                                               |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name                        |    | Max Denominator High Byte Max Denominator Low Byte |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### Bit definitions:

• 16-bit value: Used during auto calibration





## 7.7.8 Relative Rotation Angle

|             | Relative Rotation Angle (0x8E) |      |   |   |   |   |   |   |  |
|-------------|--------------------------------|------|---|---|---|---|---|---|--|
| Bit Number  | 7                              | 6    | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Data Access |                                | Read |   |   |   |   |   |   |  |
| Name        | Relative degrees               |      |   |   |   |   |   |   |  |

### Bit definitions:

• Bit 7-0: Delta in degrees from previous cycle (0°-180°)

## 7.7.9 Movement counter/timer

|             | Movement counter/timer (0x8F)   |      |   |   |   |   |   |   |  |  |
|-------------|---------------------------------|------|---|---|---|---|---|---|--|--|
| Bit Number  | 7                               | 6    | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| Data Access |                                 | Read |   |   |   |   |   |   |  |  |
| Name        | Movement Counter Movement Timer |      |   |   |   |   |   |   |  |  |

## Bit definitions:

• Bit 7-4: Movement Counter

o 0-7: Counter used to detect movement

• Bit 3-0: Movement Timer

o 0-31: Timer used to detect movement





## 7.8 Device and Power Mode Settings

## 7.8.1 General System Settings

|             | General System Settings (0xD0) |              |               |             |                 |                      |                 |              |  |  |
|-------------|--------------------------------|--------------|---------------|-------------|-----------------|----------------------|-----------------|--------------|--|--|
| Bit Number  | 7                              | 6            | 5             | 4           | 3               | 2                    | 1               | 0            |  |  |
| Data Access |                                | Read/Write   |               |             |                 |                      |                 |              |  |  |
| Name        | Soft<br>reset                  | Ack<br>reset | Event<br>mode | <u>8Mhz</u> | Comms<br>in ATI | Small<br>ATI<br>band | Redo<br>ATI all | Do<br>reseed |  |  |
| Default     |                                |              | 0             | 0           | 0               | 0                    |                 |              |  |  |

#### Bit definitions:

- Bit 7: Soft Reset (Set only, will clear when done)
  - □ 1 Causes the device to perform a WDT reset
- Bit 6: Acknowledge reset (Set only, will clear when done)
  - 1 Acknowledge that a reset has occurred. This event will trigger until acknowledged
- Bit 5: Communication mode select:
  - o 0 Streaming communication mode enabled
  - 1 Event communication mode enabled
- Bit 4: Main clock frequency selction
  - o 0 Run FOSC at 16Mhz
  - 1 Run FOSC at 8 Mhz
- Bit 3: Communication during ATI select:
  - 0 No communication during ATI
  - 1 Communications continue regardless of ATI state
- Bit 2: ATI band selection
  - 0 Re-ATI when outside 1/8 of ATI target
  - 1 Re-ATI when outside 1/16 of ATI target
- Bit 1: Redo ATI on all channels (Set only, will clear when done)
  - 1 Start the ATI process
- Bit 0: Reseed All Long term filters (Set only, will clear when done)
  - 1 Start the Reseed process





#### 7.8.2 Active Channels Mask

|             | Active Channels Mask (0xD1) |            |     |     |     |     |     |     |  |  |
|-------------|-----------------------------|------------|-----|-----|-----|-----|-----|-----|--|--|
| Bit Number  | 7                           | 6          | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
| Data Access |                             | Read/Write |     |     |     |     |     |     |  |  |
| Name        |                             |            | CH5 | CH4 | CH3 | CH2 | CH1 | CH0 |  |  |
| Default     |                             | 0x3F       |     |     |     |     |     |     |  |  |

#### Bit definitions:

- Bit 5: CH5 (note: Ch2, Ch3, Ch4 and Ch5 must all be enabled for Hall effect rotation UI to be functional)
  - o 0: Channel is disabled
  - o 1: Channel is enabled
- Bit 4: CH4 (note: Ch2, Ch3, Ch4 and Ch5 must all be enabled for Hall effect rotation UI to be functional)
  - o 0: Channel is disabled
  - o 1: Channel is enabled
- Bit 3: CH3 (note: Ch2, Ch3, Ch4 and Ch5 must all be enabled for Hall effect rotation UI to be functional)
  - o 0: Channel is disabled
  - o 1: Channel is enabled
- Bit 2: CH2 (note: Ch2, Ch3, Ch4 and Ch5 must all be enabled for Hall effect rotation UI to be functional)
  - o 0: Channel is disabled
  - o 1: Channel is enabled
- Bit 1: CH1
  - o 0: Channel is disabled
  - 1: Channel is enabled
- Bit 0: CH0
  - o 0: Channel is disabled
  - o 1: Channel is enabled





## 7.8.3 Power Mode Settings

| Power Mode Settings (0xD2) |      |                 |                    |       |        |           |         |             |  |  |
|----------------------------|------|-----------------|--------------------|-------|--------|-----------|---------|-------------|--|--|
| Bit Number                 | 7    | 6               | 5                  | 4     | 3      | 2         | 1       | 0           |  |  |
| Data Access                |      | Read/Write      |                    |       |        |           |         |             |  |  |
| Name                       | -    | Enable ULP Mode | Disable Auto Modes | Power | r mode | <u>NP</u> | segment | <u>rate</u> |  |  |
| Default                    | 0x03 |                 |                    |       |        |           |         |             |  |  |

#### Bit definitions:

- Bit 6: Enable Ultra-Low Power Mode
  - 0: ULP is disabled during auto-mode switching
  - 1: ULP is enabled during auto-mode switching
- Bit 5: Disable auto mode switching
  - o 0: Auto mode switching is enabled
  - 1: Auto mode switching is disabled
- Bit 4-3: Manually select Power Mode (note: bit 5 must be set)
  - 00: Normal Power mode. The device runs at the normal power rate, all enabled channels and UIs will execute.
  - 01: Low Power mode. The device runs at the low power rate, all enabled channels and UIs will execute.
  - o 10: Ultra-Low Power mode. The device runs at the ultra-low power rate, Ch0 is run as wake-up channel. The other channels execute at the NP-segment rate.
  - 11: Halt Mode. No conversions are performed; the device must be removed from this mode using an I2C command. Disable Auto Mode switching by setting Bit 5.
- Bit 2-0: Normal Power Segment update rate
  - o 000: 1/2 ULP rate
  - o 001: 1/4 ULP rate
  - o 010: 1/8 ULP rate
  - 011: 1/16 ULP rate100: 1/32 ULP rate
  - 100: 1/32 ULF rate
     101: 1/64 ULP rate
  - o 110: 1/128 ULP rate
  - o 111: 1/256 ULP rate

### 7.8.4 Normal/Low/Ultra-Low power mode report rate

|                                                        | Normal/Low/Ultra-Low power mode report rate (0xD3 - 0xD5) |            |   |   |   |   |   |   |  |  |
|--------------------------------------------------------|-----------------------------------------------------------|------------|---|---|---|---|---|---|--|--|
| Bit Number                                             | 7                                                         | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| Data Access                                            |                                                           | Read/Write |   |   |   |   |   |   |  |  |
| Name Normal/Low power/Ultra-low power mode report rate |                                                           |            |   |   |   |   |   |   |  |  |

### Register addresses:

- 0xD3: Normal mode report rate in ms (Default: 10 ms) (note: LPOSC timer has +- 4 ms accuracy)
- 0xD4: Low power mode report rate in ms (Default: 48 ms) (note: LPOSC timer has +- 4 ms accuracy)
- 0xD5: Ultra-low power mode report rate in 16 ms ticks (Default: 128 ms)





#### 7.8.5 Auto Mode Time

|             | Auto Mode Time (0xD6) |                 |  |      |        |  |  |  |  |  |
|-------------|-----------------------|-----------------|--|------|--------|--|--|--|--|--|
| Bit Number  | 7                     | 7 6 5 4 3 2 1 0 |  |      |        |  |  |  |  |  |
| Data Access |                       | Read/Write      |  |      |        |  |  |  |  |  |
| Name        |                       |                 |  | Mode | e time |  |  |  |  |  |
| Default     |                       | 0x14 = 10  sec  |  |      |        |  |  |  |  |  |

#### Bit definitions:

Bit 7-0: Auto modes switching time in 500 ms ticks

## 7.8.6 RDY timeout period<sup>1</sup>

|             | RDY timeout period <sup>1</sup> (0xD8) |                          |   |   |   |   |   |   |  |  |
|-------------|----------------------------------------|--------------------------|---|---|---|---|---|---|--|--|
| Bit Number  | 7                                      | 6                        | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| Data Access |                                        | Read/Write               |   |   |   |   |   |   |  |  |
| Name        |                                        | RDY timeout period value |   |   |   |   |   |   |  |  |
| Default     |                                        | 0x20 = 10.24  ms         |   |   |   |   |   |   |  |  |

#### Bit definitions:

• Bit 7-0: RDY timeout period = RDY timeout period value \* 0.32 ms

 $\circ$  0 – 81.6 ms: RDY timeout period

Default RDY timeout on IQS624V1 is 2.038 ms and cannot be changed.

## 7.8.7 I<sup>2</sup>C Settings<sup>1</sup>

|             | I <sup>2</sup> C Settings <sup>1</sup> (0xD9) |                      |                     |   |   |      |      |   |  |  |
|-------------|-----------------------------------------------|----------------------|---------------------|---|---|------|------|---|--|--|
| Bit Number  | 7                                             | 6                    | 5                   | 4 | 3 | 2    | 1    | 0 |  |  |
| Data Access | Read/Write                                    | Read/Write           | Read/Write          |   |   | -    |      |   |  |  |
| Name        | Stop Disable                                  | R/O Check<br>Disable | NP Stream<br>Enable |   |   | Rese | rved |   |  |  |
| Default     | 0                                             | 0                    | 0                   | 0 | 0 | 0    | 0    | 1 |  |  |

### Bit definitions:

- Bit 7: Stop disable
  - o 0: Stop enabled: Stop bit will exit the communication window.
  - 1: Stop disabled: Stop bit will not exit the communication window. No start within the RDY timeout period (0xD8) will exit the communication window without executing commands.
- Bit 6: Disable Read Only Check
  - o 0: Normal R/O check is performed.
  - 1: R/O check is disabled.
- Bit 5: Always stream in Normal Power Mode
  - o 0: Streaming override disabled
  - o 1: Always stream in NP
- Bit 4 1: Reserved
  - o Do not configure, leave cleared.
- Bit 0: Reserved
  - $\circ$  Must always be set (bit 0 = 1).

\_\_\_

<sup>&</sup>lt;sup>1</sup> Only Available on IQS624-32





## 8. Electrical characteristics

## 8.1 Absolute Maximum Specifications

The following absolute maximum parameters are specified for the device:

Exceeding these maximum specifications may cause damage to the device.

**Table 8-1 Absolute maximum specification** 

| Parameter                                      | IQS624-3yy              | IQS624-5yy           |  |  |  |
|------------------------------------------------|-------------------------|----------------------|--|--|--|
| Operating temperature                          | -20°C to 85°C           |                      |  |  |  |
| Supply voltage range (VDDHI – GND)             | 2.00V - 3.6V            | 2.4V - 5.5V          |  |  |  |
| Maximum pin voltage                            | VDDHI + 0.5V (may no    | ot exceed VDDHI max) |  |  |  |
| Maximum continuous current (for specific Pins) | 10r                     | mA                   |  |  |  |
| Minimum pin voltage                            | GND -                   | - 0.5V               |  |  |  |
| Minimum power-on slope                         | 100                     | V/s                  |  |  |  |
| ESD protection                                 | ±4kV (Human body model) |                      |  |  |  |

## 8.2 Voltage regulation specifications

**Table 8-2 Internal regulator operating conditions** 

| Description                | Chipset    | Parameter  | MIN  | TYP  | MAX  | UNIT |
|----------------------------|------------|------------|------|------|------|------|
| Supply Voltage             | 100624 250 | $V_{DDHI}$ | 2    | ı    | 3.6  | V    |
| Internal Voltage Regulator | IQS624-3yy | $V_{REG}$  | 1.63 | 1.66 | 1.69 | V    |
| Supply Voltage             | IOS624 Eva | $V_{DDHI}$ | 2.4  | ı    | 5.5  | V    |
| Internal Voltage Regulator | IQS624-5yy | $V_{REG}$  | 1.67 | 1.7  | 1.73 | V    |





## 8.3 Reset Conditions

**Table 8.3 Start-up and shut-down slope Characteristics** 

| DESCRIPTION               | Conditions                                    | PARAMETER            | MIN              | MAX               | UNIT |
|---------------------------|-----------------------------------------------|----------------------|------------------|-------------------|------|
| Power On Reset            | V <sub>DDHI</sub> Slope ≥ 100V/s¹             | POR <sub>VDDHI</sub> | 0.3 <sup>2</sup> | 1.7               | V    |
| VDDHI<br>Brown Out Detect | V <sub>DDHI</sub> Slope ≥ 100V/s <sup>1</sup> | BOD <sub>VDDHI</sub> | N/A              | 1.7               | V    |
| VREG<br>Brown Out Detect  | V <sub>DDHI</sub> Slope ≥ 100V/s¹             | BOD <sub>VREG</sub>  | N/A              | 1.58 <sup>3</sup> | V    |

## 8.4 Digital input/output trigger levels

Table 8-4 Digital input/output trigger level specifications

| Description               | Conditions              | Parameter            | Temperature    | MIN            | TYP            | MAX            | UNIT           |                |       |  |       |  |      |
|---------------------------|-------------------------|----------------------|----------------|----------------|----------------|----------------|----------------|----------------|-------|--|-------|--|------|
| I                         |                         | V <sub>in_LOW</sub>  | -20°C          | 32.12          |                |                |                |                |       |  |       |  |      |
| Input low level voltage   |                         |                      | +25°C          |                | 34.84          |                |                |                |       |  |       |  |      |
| voitage                   |                         |                      | +85°C          |                |                | 39.39          |                |                |       |  |       |  |      |
| In most letaile           | 400kHz I <sup>2</sup> C | V <sub>in_HIGH</sub> | -20°C          |                |                | 71.51          |                |                |       |  |       |  |      |
| Input high level voltage  | clock                   |                      | $V_{in\_HIGH}$ | $V_{in\_HIGH}$ | $V_{in\_HIGH}$ | $V_{in\_HIGH}$ | $V_{in\_HIGH}$ | $V_{in\_HIGH}$ | +25°C |  | 68.18 |  | % of |
| level voltage             | frequency               |                      | +85°C          | 66.06          |                |                | VDDHI          |                |       |  |       |  |      |
| Output low level voltage  | , ,                     | $V_{out\_LOW}$       | -20°C – +85°C  |                | 0              |                |                |                |       |  |       |  |      |
| Output high level voltage |                         | $V_{out\_HIGH}$      | -20°C – +85°C  |                | 100            |                |                |                |       |  |       |  |      |

<sup>&</sup>lt;sup>1</sup>Applicable to full "operating temperature" range

 $<sup>^2\</sup>mbox{For a power cycle, ensure lowering VDDHI below the minimum value before ramping VDDHI past the maximum POR value$ 

<sup>&</sup>lt;sup>3</sup>Reference schematic - Capacitors C1 & C2 should be chosen to comply with this specification







## 8.5 Current consumptions

**Table 8-5 IC subsystem current consumption** 

| Description        | TYP  | MAX | UNIT |
|--------------------|------|-----|------|
| Core active        | 339  | 377 | μΑ   |
| Core sleep         | 0.63 | 1   | μΑ   |
| Hall sensor active | 1.5  | 2   | mA   |

Table 8-6 IC subsystem typical timing

| Description | Core active | Core sleep | Hall sensor active | Total  | Unit |
|-------------|-------------|------------|--------------------|--------|------|
| Normal      | 5           | 5          | 0.5                | 10     | ms   |
| Low         | 5           | 43         | 0.5                | 48     | ms   |
| Ultra-low   | 1.75        | 128        | 0                  | 129.75 | ms   |





## 8.5.1 Capacitive sensing alone

## **Table 8-7 Capacitive sensing current consumption**

| Solution | Power mode | Conditions | Report rate | TYPICAL | UNIT |
|----------|------------|------------|-------------|---------|------|
|          | NP mode    | VDD = 2.0V | 10 ms       | 43.5    | μΑ   |
|          | NP mode    | VDD = 3.3V | 10 ms       | 44.4    | μΑ   |
| 3.3V     | LP mode    | VDD = 2.0V | 48 ms       | 13.3    | μA   |
| 3.3V     | LP mode    | VDD = 3.3V | 48 ms       | 13.8    | μΑ   |
|          | ULP mode   | VDD = 2.0V | 128 ms      | 3.9     | μΑ   |
|          | ULP mode   | VDD = 3.3V | 128 ms      | 4.5     | μΑ   |
|          | NP mode    | VDD = 2.5V | 10 ms       | 51.3    | μA   |
|          | NP mode    | VDD = 5.5V | 10 ms       | 52.3    | μΑ   |
| 5V       | LP mode    | VDD = 2.5V | 48 ms       | 14.5    | μΑ   |
| 5 V      | LP mode    | VDD = 5.5V | 48 ms       | 15.5    | μΑ   |
|          | ULP mode   | VDD = 2.5V | 128 ms      | 3.9     | μA   |
|          | ULP mode   | VDD = 5.5V | 128 ms      | 5.1     | μA   |

<sup>-</sup>These measurements where done on the default setup of the IC





## 8.5.2 Hall-effect sensing alone

## **Table 8-8 Hall-effect current consumption**

| Solution | Power mode | Conditions | Report rate | TYPICAL | UNIT |
|----------|------------|------------|-------------|---------|------|
| 3.3V     | NP mode    | VDD = 2.0V | 10 ms       | 215.2   | μΑ   |
| 3.3V     | NP mode    | VDD = 3.3V | 10 ms       | 212.6   | μΑ   |
| 3.3V     | LP mode    | VDD = 2.0V | 48 ms       | 58.3    | μΑ   |
| 3.3V     | LP mode    | VDD = 3.3V | 48 ms       | 55.1    | μΑ   |
| 3.3V     | LP mode    | VDD = 2.0V | 128 ms      | TBA     | μΑ   |
| 3.3V     | LP mode    | VDD = 3.3V | 128 ms      | 19.65   | μΑ   |
| 5V       | NP mode    | VDD = 2.5V | 10 ms       | 240.0   | μΑ   |
| 5V       | NP mode    | VDD = 5.5V | 10 ms       | 239.3   | μΑ   |
| 5V       | LP mode    | VDD = 2.5V | 48 ms       | 64.1    | μΑ   |
| 5V       | LP mode    | VDD = 5.5V | 48 ms       | 64.8    | μΑ   |

<sup>-</sup>These measurements where done on the default setup of the IC

It is not advised to use the IQS624 in ULP without capacitive sensing. This is due to the Hall-effect sensor being disabled in ULP.

## 8.5.3 Halt mode

**Table 8-9 Halt mode current consumption** 

| Solution | Power mode | Conditions | TYPICAL | UNIT |
|----------|------------|------------|---------|------|
| 3.3V     | Halt mode  | VDD = 2.0V | 1.6     | μΑ   |
| 3.3V     | Halt mode  | VDD = 3.3V | 1.9     | μΑ   |
| 5V       | Halt mode  | VDD = 2.5V | 1.1     | μΑ   |
| 5V       | Halt mode  | VDD = 5.5V | 2.2     | uА   |



## 9. Package information

## 9.1 DFN10 package and footprint specifications





**Side View** 



Table 9-1: QFN(3x3)-10 Package Dimensions

| Dimension | [mm]        | Dimension | [mm]      |
|-----------|-------------|-----------|-----------|
| А         | 3.0±0.1     | D1        | 2.4±0.05  |
| В         | 3.0±0.1     | D2        | 1.65±0.05 |
| С         | 0.75±0.05   | Е         | 0.25±0.05 |
| C1        | 0.025±0.025 | E1        | 0.5±0.05  |
| C2        | 0.203±0.05  | F         | 0.4±0.05  |

Table 9-2 DFN-10 Landing dimensions

| Dimension | [mm] |
|-----------|------|
| Α         | 2.4  |
| В         | 1.65 |
| С         | 0.8  |
| D         | 0.5  |
| E         | 0.3  |
| F         | 3.2  |



Figure 9-1 DFN-10 Landing dimension



## 9.2 WLCSP-9 package and footprint specifications



## Notes

- 1. ALL DIMENSIONS ARE IN MILLIMETERS (ANGLES IN DEGREES).
- 2. DIMENSIONING AND TOLERANCING PER ANSI Y14.5M-1994.

|      | Dimensional Ref.      |                |       |  |  |
|------|-----------------------|----------------|-------|--|--|
| REF. | Min.                  | Min. Nom. Max. |       |  |  |
| Α    | 0.300                 | 0.340          | 0.380 |  |  |
| Α1   | 0.075                 | 0.090          | 0.105 |  |  |
| Α2   | 0.205                 | 0.230          | 0.255 |  |  |
| D    | 1.055                 | 1.070          | 1.085 |  |  |
| E    | 1.515                 | 1.530          | 1.545 |  |  |
| D1   | 0.650                 | 0.70           | 0.750 |  |  |
| E1   | 0.950                 | 1.000          | 1.050 |  |  |
| Ь    | 0.135                 | 0.160          | 0.185 |  |  |
| Ъ    | 0                     | .350 BS        | C     |  |  |
| உ    | 0                     | .500 BS        | C     |  |  |
| SD   |                       | 0.035          |       |  |  |
| SE   |                       | 0.050          |       |  |  |
| To   | Tol. of Form&Position |                |       |  |  |
| ааа  | 0.10                  |                |       |  |  |
| ЬЬЬ  | 0.10                  |                |       |  |  |
| ccc  |                       | 0.05           |       |  |  |
| ддд  |                       | 0.05           |       |  |  |

Figure 9-2 IQS624 WLCSP-9 package dimensions





## 9.3 Device marking and ordering information

## 9.3.1 Device marking:



### Notes:

- (1) 5V version is not in mass production, only available on special request.
- (2) Other sub-addresses available on special request, see Section 6.6.

## 9.3.2 Ordering Information:

## IQS624-xzyyppb

x – Version

3 or 5

z - IC Revision

blank or 2

yy - Config

00 or 01

pp - Package type

DN: DFN (3x3)-10

CS: WLCSP-9

b – Bulk packaging

R (3k per reel, MOQ=1 Reel)

### **Example:**

#### IQS624-3200DNR

- 3 refers to 3V version
- 2 refers to software version 2
- 00 config is default (44H sub-address)
- DN DFN(3x3)-10 package
- R packaged in Reels of 3k (has to be ordered in multiples of 3k)



## 9.4 Tape and reel specification

## 9.4.1 DFN(3x3)-10





SECTION A - A

A0=3.30 B0=3.30 K0=1.10

#### NOTES

- 1、10 SPROCKET HOLE PITCH CUMULATIVE TOLERANCE ±0.2
- 2. CAMBER IN COMPLIANCE WITH EIA 481
- 3. POCKET POSITION RELATIVE TO SPROCKET HOLE MEASURED AS TRUE POSITION OF POCKET, NOT POCKET HOLE





## 9.4.2 WLCSP-9









## 9.5 MSL Level

**Moisture Sensitivity Level** (MSL) relates to the packaging and handling precautions for some semiconductors. The MSL is an electronic standard for the time period in which a moisture sensitive device can be exposed to ambient room conditions (approximately 30°C/85%RH see J-STD033C for more info) before reflow occur.

| Package     | Level (duration)                                         |
|-------------|----------------------------------------------------------|
|             | MSL 1 (Unlimited at ≤30°C / 85% RH)                      |
| DFN(3x3)-10 | Reflow profile peak temperature < 260°C for < 25 seconds |
|             | Number of reflows < 3                                    |
|             | MSL 1 (Unlimited at ≤30°C / 85% RH)                      |
| WLSCP-9     | Reflow profile peak temperature < 260°C for < 25 seconds |
|             | Number of reflows < 3                                    |





## **Datasheet revisions**

## 10.1 Revision history

V0.1 - Preliminary structure V1.03a - Preliminary datasheet

V1.04a - Corrected: Updated 0x43-0x44 registers: ATI base is [7:6] and not [7:5]

Added 0x72 and 0x73 registers: ATI settings for CH 2-5

Added Streaming and event mode chapters

Added 5V and 3.3V solution

V1.05a- Corrected: Changed ESD rating

Added calibration and magnet orientation appendix

Added induction to summary page

Updated schematic Updated disclaimer

Updated software and hardware number

V1.10 - Changed from preliminary to production datasheet

Hall ATI Explanation Added:

Current measurements for power modes

Register Configuration

Calibration calculations Updated:

Current consumption on overview

**Appendices** 

Pinout update, pin 9 - NC

V1.11 - Added: Device markings, order information

Relative/ absolution summary to appendix

Updated: Supply voltage range

Reference schematic

Updated MSL data

V1.12 - Updated: Title **Images** 

V1.14 – Updated: Corrected low and high byte order in Register table V1.15 – Updated: Corrected minimum temperature and voltage spec

V1.16 – Updated: Corrected magnet specification V1.17 – Updated: Updated magnet spec in appendix V.1.18 - Added: Normal Power Maximum report rate

V1.19 - Added: Errata: Hall ATI values

I2C Protocol

IQS624 Memory Map Updated:

Small User Interaction Detection UI Removed:

V1.20 - Updated: Errata: Hall ATI values IQS624 Memory Map

V1.21 – Updated: MSL Data

Added:

Appendix A

Errata: Hall ATI values

V1.22 - Added: Voltage regulation specification V1.23 - Removed: Ready Active High Configuration

Added: ProxFusion® Sensitivity (Section 1)

Digital input/output trigger levels (Section 8) Errata: Hall ATI values Updated:

Minor updates

New Software V2 Registers in Memory Map V2.00 - Added:

V2.01 - Removed: UI Flags, 0x11 (Unused on FW) Updated: Appendix B: Magnet Calibration

Reference Schematic

FG Bank 3 Calibration Data

Section 6.5 Stop-bit Disable Option

Section 4.6 Interval UI

Section 4.7 Wheel Wake Preload Section 4.8 Event Mode Options Section 9: Package Information

V2.02 Updated: V2.03 Updated: Section 8: Reset Conditions WLCSP-9 Information Added:





## 10.2 Errata

## 10.2.1 Hall ATI values<sup>1</sup> (Not Required for IQS624-32

A software setup change is required for the hall ATI compensation values. During setup of the IQS624, wait for the ATI busy flag to clear in the <u>System flags (10H)</u> register. The following sequence should be followed after the ATI busy flag is cleared:

- 1. I2C Start
- 2. Write 0xD4 to register 0xF0
- 3. Write 0xFF to register 0xF1
- 4. I2C Stop
- 5. I2C Start
- 6. Write 0xD5 to register 0xF0
- 7. Write 0x00 to register 0xF1
- 8. I2C Stop

This setup change will fix errors regarding the hall ATI algorithm that may occur under certain conditions. This setup requires one rotation for the compensation values to be accurately adjusted. The following procedure should be followed if an accurate absolute degree value is required at startup.

- Follow the startup procedure as usual write the registers and do an ATI
- Rotate the wheel 360 degrees
- Read the updated compensation values
  - o I2C Start
  - Write 0xD4 to register 0xF0
  - I2C Stop
  - o I2C Start
  - Read from register 0xF1
  - o I2C Stop
  - o I2C Start
  - Write 0xD5 to register 0xF0
  - o I2C Stop
  - o I2C Start
  - Read from register 0xF1
  - I2C Stop
- The two values that has been read should replace 0xFF and 0x00 respectively in the
  procedure described in 10.2.1. This calibration only needs to be done once and the
  absolute degree value at startup should be correct. See <a href="On-Chip Compensation">On-Chip Compensation</a> for more
  details.

<sup>&</sup>lt;sup>1</sup> Not Required on IQS624-32





## 11. Contact Information

|                     | USA                                                                 | Asia                                                                                | South Africa                                     |
|---------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------|
| Physical<br>Address | 6507 Jester Blvd<br>Bldg 5, suite 510G<br>Austin<br>TX 78750<br>USA | Rm1227, Glittery City<br>Shennan Rd<br>Futian District<br>Shenzhen, 518033<br>China | 109 Main Street<br>Paarl<br>7646<br>South Africa |
| Postal<br>Address   | 6507 Jester Blvd<br>Bldg 5, suite 510G<br>Austin<br>TX 78750<br>USA | Rm1227, Glittery City<br>Shennan Rd<br>Futian District<br>Shenzhen, 518033<br>China | PO Box 3534 Paarl 7620 South Africa              |
| Tel                 | +1 512 538 1995                                                     | +86 755 8303 5294<br>ext 808                                                        | +27 21 863 0033                                  |
| Fax                 | +1 512 672 8442                                                     |                                                                                     | +27 21 863 1512                                  |
| Email               | info@azoteq.com                                                     | info@azoteq.com                                                                     | info@azoteq.com                                  |

Please visit www.azoteg.com for a list of distributors and worldwide representation.

The following patents relate to the device or usage of the device: US 6,249,089; US 6,952,084; US 6,984,900; US 8,395,395; US 8,531,120; US 8,659,306; US 9,209,803; US 9,360,510; US 9,496,793; US 9,709,614; US 9,948,297; EP 2,351,220; EP 2,559,164; EP 2,748,927; EP 2,846,465; HK 1,157,080; SA 2001/2151; SA 2006/05363; SA 2014/01541; SA 2017/02224;

AirButton®, Azoteq®, Crystal Driver®, IQ Switch®, ProxSense®, ProxFusion®, LightSense™, SwipeSwitch™, and the logo are trademarks of Azoteq.

The information in this Datasheet is believed to be accurate at the time of publication. Azoteq uses reasonable effort to maintain the information up-to-date and accurate, but does not warrant the accuracy, completeness or reliability of the information contained herein. All content and information are provided on an "as is" basis only, without any representations or warranties, express or implied, of any kind, including representations about the suitability of these products or information for any purpose. Azoteq disclaims all warranties and conditions with regard to these products and information, including but not limited to all implied warranties and conditions of merchantability, fitness for a particular purpose, title and non-infringement of any third party intellectual property rights. Azoteq assumes no liability for any damages or injury arising from any use of the information or the product or caused by, without limitation, failure of performance, error, omission, interruption, defect, delay in operation or transmission, even if Azoteq has been advised of the possibility of such damages. The applications mentioned herein are used solely for the purpose of illustration and Azoteq makes no warranty or representation that such applications will be suitable without further modification, nor recommends the use of its products for application that may present a risk to human life due to malfunction or otherwise. Azoteq products are not authorized for use as critical components in life support devices or systems. No licenses to patents are granted, implicitly, express or implied, by estoppel or otherwise, under any intellectual property rights. In the event that any of the abovementioned limitations or exclusions does not apply, it is agreed that Azoteq's total liability for all losses, damages and causes of action (in contract, tort (including without limitation, negligence) or otherwise) will not exceed the amount altiputable to make corrections, deletions, enhancements, improvements and other changes to th

#### www.azoteq.com/ip

info@azoteq.com





## 12. Appendices

## 12.1 Appendix A: Magnet orientation

The IQS624 is able to calculate the angle of a magnet using two Hall sensors which are located in two corners of the die within the package. The two Hall sensors gather data of the magnet field strength in the z-axis. The difference between the two Hall sensors' data can be used to calculate a phase. This phase difference can then be transformed to degrees.

Key considerations for the IQS624:

- There must be a phase difference of 20° to 50° between the two Hall sensors. It's impossible to calculate the angle if the phase difference is 0° or 180°.
- Reasonable N/S swing on each Hall sensor
   A reasonable peak to peak signal is needed on the plates to ensure optimal on-chip angle calculation.

**Table 12-1 Typical recommended magnet** 

| Outer Radius | Inner Radius | Width | Grade | Distance between IC and Magnet axis |
|--------------|--------------|-------|-------|-------------------------------------|
| 2.5 mm       | 1 mm         | 3 mm  | N40   | 4 mm                                |

Note: Increasing the width of the magnet can improve error caused by movement in the axis direction.

Ideal design considerations:

- Stable phase difference This helps with the linearity of the maths.
- Big phase difference The maths involved has better results with bigger phase difference.
- Distance between the sensors and the magnet should be the same for both this insures that the magnet fields observed on both sensors are relatively the same.







Figure 12-1 - Technical Drawing showing DIE placement within the package. The Hall-Plates are shown as the two green pads in the corners of the DIE. Package axis and hall-plate axis are also shown.

### 12.1.1 Absolute or relative applications

There are two general applications for a Hall sensor, absolute and relative.

An **absolute application** requires the physical absolute angle of the magnet as an input. It is only possible to obtain the physical angle from a **dipole magnet**.

A **relative application** requires the difference between two positions of the magnet as an input. This makes it possible to use either a **dipole or multipole magnet**. The relative application can also be referred to as an incremental application.

### 12.1.2 Absolute off-axis magnet position relative to IC:

The IQS624 can be used as an off-axis hall rotation sensor. This means that the IC is placed on a PCB with the PCB parallel to the axis which it is measuring.











Figure 12-2 Magnet's postion reletave to IC with off-axis orientation

Table 12-2 Typical specifications of off-axis magnet position

|   | Variables                             | Typical       |
|---|---------------------------------------|---------------|
| Α | Outer radius                          | 2.5 mm        |
| В | Inner radius                          | 1 mm          |
| С | Thickness of magnet                   | 1.25 mm       |
| D | Distance between IC and Magnet Axis   | 3.5 mm        |
| Е | Angle of magnet relative to IC        | 34.53 degrees |
| F | Residual inductance (B <sub>r</sub> ) | 1.25 T        |
| G | Polarization                          | Diametrical   |
| Н | Magnetic grading                      | N40           |

## 12.1.3 Relative on-axis magnet position relative to IC:

The IQS624 as an on-axis hall rotation sensor. This means that the IC is placed on a PCB with the PCB perpendicular to the axis which it is measuring.







Figure 12-3 Magnet's postion relative to IC with on-axis orientation

Table 12-3 Typical specifications of on-axis magnet position

|   | Variables                             | Typical     |
|---|---------------------------------------|-------------|
| Α | Outer radius                          | 2.5 mm      |
| В | Inner radius                          | 1 mm        |
| С | Thickness of magnet                   | 2 mm        |
| D | Distance between IC and Magnet        | 2 mm        |
| Е | Residual inductance (B <sub>r</sub> ) | 1.25 T      |
| F | Polarization                          | Diametrical |
| G | Magnetic grading                      | N40         |

#### **Preferred magnet orientation comments**

Both solutions promote the ideal conditions. However, the EV kit with the magnet parallel with the IC could be more ideal as shown previously. This design was chosen to display the ease of placement our product offers with the built-in corrections and linearization algorithms.

Small movements of the magnet have less impact on the phase difference.

The distance between the magnet and the two sensors are relatively equivalent.

### **12.1.4 Alternative orientation**

### Off-centred perpendicular diametrical magnet

Here are two possible solutions. Note that both are off-centred. This is to ensure that a phase difference between the two signals are detected.







Figure 12-4 A slightly off centred diametrical ring magnet and a diametrical barrel magnet next to the IC. The distance between the sensor and the magnet is greater in this solution, thus a stronger magnet is suggested.

**Please note**: The rectangles which represent the hall sensors in these diagrams are only approximations of where the hall sensors can be found and is not to scale.

Even though these solutions will work we do not encourage their use. We designed this product with the idea to promote easy usage and fewer physical restrictions to the usage. These solutions require more critical design on the physical layout and rigidness in the final project.





## 12.2 Appendix B: Magnet calibration

The phase angle and the hall channels need to be calibrated on the IQS624. This can be done by a single rotation using the IQS624 GUI. The phase angle needs to be calibrated to calculate the angle between the magnet and IC while the hall channels need to be calibrated to determine the strength of the magnet.

## 12.2.1 Calibration During IC Production

The IQS624 is calibrated during IC production. The calibration ensures a more accurate and linear relation between the magnet and hall plates. Each IC is assigned to a calibration bin between 1 and 15. The bin index is stored in the lower nibble of Floating Gate 3. It is advised to use the bin index to ensure better accuracy over production. The calibration procedure was designed to ensure that the correct Hall ATI Settings are chosen for each setup.

The ATI target of each hall plate needs to be calibrated for the specific magnet strength of the application. Using the calibration data the signal is calculated using the equation below:

$$i_a = I \times N_B (N_T^{-1} - n_z^{-1})$$

Where:

 $i_a = Signal$ 

I = DC Current

 $N_B = Base\ Value\ Counts$ 

 $N_T = ATI Target$ 

 $n_z = Maximum Counts$ 

It is not necessary to implement this equation on FW. The procedure below describes 5 easy steps to calibrate each application. The equation is used to generate a calibration table in the GUI which can be implemented in product FW. Therefore, the bin value of each IC is used to find the correct value in the Hall Wheel Calibration table generated by the GUI.

### 12.2.2 How to calibrate using the IQS624 GUI

Each application/setup (not every single IC) should be calibrated with a single rotation to calculate the phase angle and ATI target values. The IQS624 GUI (from V1.0.2.13) should be used to calculate the correct calibration table for each application. A default "Max Counts" of 1500 is suggested. It should be noted that IC which were not calibrated during IC production will not be able to be calibrated for hall ATI settings. This procedure can still be used for phase angle calibration.





### Step 1: Click on the Calibration button in the GUI.

- a) This banner indicates that the calibration progress has started.
- b) The user must rotate the wheel on the IQS624 device 360 degrees.

(It is encouraged that the wheel must be rotated at a constant and low speed)



Step 2: Complete one full rotation until the "Calibration Completed" message is received.

(Repeat step 1 if the message: "Calibration Failed" is received.)







## **Step 3: Obtaining the Hall ATI Settings**

- a) Click on Settings
- b) Click on OTP Setup
- c) Click on Calculate Table Values
- d) Click on Apply Targets and Base



#### **Step 4: Inspect the channels**

Check if the "Max Counts" selected for this application is reached (default = 1500). The base values or the Max Counts can be adjusted if this is not the case. Repeat Step 1-3 after the base values are adjusted.

## **Step 5: Obtaining the phase angle calibration constants**

- a) Click on Hall Settings
- b) The phase angle calibration constants The Sin phase and Cos phase are the two constants which are written to the device. The phase (displayed in degrees) can also be used to obtain both of these constants.







If the user is satisfied an h-file can be generated which includes the Hall ATI Settings for each IC. Click on File → Export H File

If this calibration is done on a product the constants obtained from the calibration can be used for projects with the same physical layout and magnet. This means that only one calibration is needed per product.

## 12.2.3 MCU Implementation

Before implementing the calibration data on an MCU the procedure described in Section 12.2.2 should be followed. Implement the steps below during initialisation of the MCU.

- 1. Power-up
- 2. Read the calibration index from Floating Gate 3.
  - a. I2C Start
  - b. Write 0x13 to register 0xF0
  - c. I2C Stop
  - d. I2C Start
  - e. Read from register 0xF1 and store calibration data
  - f. I2C Stop
- 3. Use the lower nibble of the floating gate to find the Hall ATI Settings in the Hall Wheel Calibration Table Values in the exported h-file from Section 12.2.2.
- 4. Write the Hall ATI Settings to registers 0x72 and 0x73 during setup of the IC.
- 5. Write the Cos and Sin constants to registers 0x79 and 0x7A.

#### For example:

- Lower nibble of Floating Gate 3 is 0x07.
- The exported Hall Wheel Calibration Table Values:

/\* Hall Wheel Calibration Table Values \*/

const static uint8\_t Ch2\_3\_HALL\_ATI\_SETTINGS[] = {0xD0, 0xD3, 0xD5, 0xD6, 0xD8, 0xD0, 0xD3, 0xD5, 0xD6, 0xD8, 0xD0, 0xD3, 0xD5, 0xD6, 0xD8};

const static uint8\_t Ch4\_5\_HALL\_ATI\_SETTINGS[] = {0xCF, 0xD1, 0xD3, 0xD4, 0xD6, 0xD0, 0xD2, 0xD4, 0xD6, 0xD1, 0xD2, 0xD4, 0xD6, 0xD8, 0xD8};

- The 7<sup>th</sup> value of each table is 0xD3 and 0xD2.
- During initialization write 0xD3 to register 0x72 and 0xD2 to register 0x73. (Hall ATI Settings)
- During initialization write 0x83 to register 0x79 and 0xDA to register 0x7A. (Phase Angle Constants)





## 12.2.4 How to calculate the phase angle using the raw data

There are two Hall Plates that make up the sensor, separated by a fixed distance in the IC package, as described previously. These plates, designated Plate 1 & Plate 2, each have two associated data channels that sense the North-South magnetic field coincident on the plates.

For Plate 1: CH2 is the non-inverted channel, and CH3 is the inverted channel.

For Plate 2: CH4 is the non-inverted channel, and CH5 is the inverted channel.

E.g. on Plate 1, if CH2 increases in value in the presence of an increasing North field, then CH3 decreases in value in the presence of an increasing North field.

The phase delta observed between the plates can be calculated from either the non-inverted, or the inverted channel pairs.

To calculate the phase delta:

### **Symbols**

| $P_n$ | Non-inverted cha | nnel of Plate n: | where $P_1 = 0$ | $CH_2$ , and $P_2 = CH_4$ |
|-------|------------------|------------------|-----------------|---------------------------|
|       |                  |                  |                 |                           |

$$P'_n$$
 Inverted channel of Plate n:  $P'_1 = CH_3$ , and  $P'_2 = CH_5$ 

 $P_n|_{max}$  Max value of the channel  $P_n|_{min}$  Min value of the channel

 $\theta_{\Lambda}$  Phase observed between the plates

#### **Calculations**

To calculate the phase, for at least one full rotation of the magnet, capturing all four channels:

First normalize the data for each channel, to obtain.

$$N(CH_n) = \frac{\frac{CH_n|_{max} - CH_n}{CH_n}}{\frac{CH_n|_{max} - CH_n|_{min}}{CH_n|_{min}}}$$
(1)

The data will now range between 0 - 1.

For the non-inverted pair:  $\{P_2, P_1\} = \{CH_4, CH_2\}$  sample both channels where  $N(CH_4) \approx 0.5$ . With these values, the phase delta can be calculated:

$$\theta_{\Lambda} = \sin^{-1}(|N(CH_4) - N(CH_2)| \cdot 2) \tag{2}$$

Likewise, the phase delta can be calculated from the inverted pair:  $\{P_2', P_1'\} = \{CH_5, CH_3\}$  sample both channels where  $N(CH_5) \approx 0.5$ .

$$\theta_{\Delta}' = \sin^{-1}(|N(CH_5) - N(CH_3)| \cdot 2) \tag{3}$$

And, while the phase angles are theoretically equal, due to misalignments,  $\theta_{\Lambda} \approx \theta_{\Lambda}'$ .

To increase accuracy of the observed phase, the two calculated phases can be averaged, leading the final Observed phase as:

$$\theta_{\Delta} = \frac{\sin^{-1}(|N(CH_4) - N(CH_2)| \cdot 2) + \sin^{-1}(|N(CH_5) - N(CH_3)| \cdot 2)}{2} \tag{4}$$

**NB:** Remember that  $\{CH_4, CH_2\}$  are evaluated at  $N(CH_4) \approx 0.5$ . While separately,  $\{CH_5, CH_3\}$  are evaluated at  $N(CH_5) \approx 0.5$ . Even when used together in Equation (4).





The IQS624 uses this phase delta as a constant to calculate the angle. The phase delta is saved on the IC after it has been converted to  $(sin(\theta_{\Delta}) \cdot 256)$  and  $(cos(\theta_{\Delta}) \cdot 256)$ . This is done to lessen computations and memory usage on the chip.

This means that if the phase were to change, the constants would need to be recalculated. If the application of this IC ensures nothing or little movement, the master device would only need to write the values each time the IC resets and would not need to re-calculate it. Making it possible to calculate the phase delta once before production and using that value for the application.

An example of well aligned channels, the phase offset visible between the inverted and non-inverted channel pairs of the two plates:



Experimentally, jog the XYZ alignment of the magnet relative to the IC and perform at least one full rotation of the magnet, assess the peaks of the channels; repeat this until all channels have approximately the same amplitude.

To change the sensitivity of the ProxEngine to Magnetic Field Strength, the ATI parameters on the IC can be adjusted as described in the following section.





## 12.3 Appendix C: Hall ATI

Azoteq's ProxFusion<sup>®</sup> Hall technology has ATI Functionality; which ensures stable sensor sensitivity. The ATI functionality is similar to the ATI functionality found in ProxSense<sup>®</sup> technology. The difference is that the Hall ATI requires two channels for a single plate.

Using two channels ensures that the ATI can still be used in the presence of the magnet. The two channels are the inverse of each other, this means that the one channel will sense North and the other South. The two channels being inverted allows the capability of calculating a reference value which will always be the same regardless of the presence of a magnet.

### 12.3.1 Hall reference value:

The equation used to calculate the reference value, per plate:

$$Ref_n = \frac{1}{2 \cdot \left(\frac{1}{P_n} + \frac{1}{P_n'}\right)}$$

### 12.3.2 ATI parameters:



The ATI process adjusts three values (Coarse multiplier, Fine multiplier, Compensation) using two parameters per plate (ATI base and ATI target). The ATI process is used to ensure that the sensor's sensitivity is not severely affected by external influences (Temperature, voltage supply change, etc.).

## 12.3.3 Coarse and Fine multipliers:

In the ATI process the compensation is set to 0 and the coarse and fine multipliers are adjusted such that the counts of the reference value (Ref) are roughly the same as the ATI Base value. This means that if the base value is increased, the coarse and fine multipliers should also increase and vice versa.

## 12.3.4 ATI-Compensation:

After the coarse and fine multipliers are adjusted, the compensation is adjusted till the reference value (Ref) reaches the ATI target. A higher target means more compensation and therefore more sensitivity on the sensor.

The ATI-Compensation adjusts chip sensitivity; and, must not be confused with the On-chip Compensation described below. On-chip Compensation corrects minor displacements or magnetic non-linearities. This compensation ensures that both channels of each plate – which represent North and South individually – have the same swing. On-chip compensation is performed in the UI and is not observable on the raw channel data.

The ATI process ensures that long term temperature changes, or bulk magnetic interference (e.g. the accidental placement of another magnet too close to the setup), do not affect the sensor's ability to detect the rotating magnet.





## 12.3.5 Recommended parameters:

There are recommended parameters to ensure optimal use. Optimally the settings would be set up to have a max swing of 1000 from peak to peak and a reference value below 1000 counts.

The recommended parameters are:

ATI Base: 100 or 150ATI Target: 500 – 1000

It is not assured that these settings will always set up the channels in the optimal region but it is recommended to rather adjust the magnet's position a little as this also influences the signal received. If the magnet is too close to the IC the swing will be too large, and thus it is recommended to increase the distance between the IC and the Magnet. Refer to Appendix B: Magnet calibration for more information when choosing the ATI target.

## 12.3.6 On-Chip Compensation

During a rotation of the magnet, the chip tracks important positions,  $0/360^{\circ}$  and  $180^{\circ}$ , as well as the MIN & MAX positions of the two plate equations  $R_b \& R_t$ 

Because the chip requires that the channels are aligned to the same amplitudes, the on-chip equations are as follows:

$$R_t = \frac{1}{CH_4} - \frac{1}{CH_2}$$
 
$$R_b = \frac{1}{CH_5} - \frac{1}{CH_3}$$
 
$$R = \frac{R_t}{R_b}$$

The Compensation Constant ( $\kappa$ ) is tracked as:

$$\kappa = \frac{Max(R_b)}{Max(R_t)}$$

With R updated as

$$R = \kappa \cdot \frac{R_t}{R_h}$$

The update is only applied under certain conditions, both the maxima or minima of  $\{R_b, R_t\}$  before crossing either 0° or 180° in a portion of the rotation. This means if the device wiggles between 150° & 200°, but does cross both maxima, the compensation is not updated.

At start-up, there is no compensation available and  $\kappa = 1$ 

**NOTE:** After calibration, a rotation of the magnet is required to update the compensation value.

The following calibration procedure should be followed if an accurate absolute degree value is required at startup for IQS624-3001.

- Follow the startup procedure as usual write the registers and do an ATI
- Rotate the wheel 360 degrees
- Read the updated compensation values
  - o I2C Start
  - Write 0xD4 to register 0xF0
  - o I2C Stop





- o I2C Start
- Read from register 0xF1 and store comp1
- o I2C Stop
- o I2C Start
- Write 0xD5 to register 0xF0
- I2C Stop
- o I2C Start
- Read from register 0xF1 and store comp2
- o I2C Stop

This calibration only needs to be done once. When these compensation values are known they can be written to the device every time on startup.

- Follow the startup procedure as usual write the registers and do an ATI
- Wait for the ATI busy flag to clear in the <u>System flags (10H)</u> register.
  - o I2C Start
  - Write 0xD4 to register 0xF0
  - Write comp1 to register 0xF1
  - o I2C Stop
  - o I2C Start
  - Write 0xD5 to register 0xF0
  - Write comp2 to register 0xF1
  - o I2C Stop