

#### **GENERAL DESCRIPTION**

The MC3430 is a low-noise, integrated digital output 3-axis accelerometer with a feature set optimized for cell phones and consumer product motion sensing.

Applications include user interface control, gaming motion input, electronic compass tilt compensation for cell phones, game controllers, remote controls and portable media products.

Accurate event detection is enabled with a low noise architecture that minimizes false triggering found in competing devices. Low noise and low power are inherent in the monolithic fabrication approach, where the MEMS accelerometer is integrated in a single-chip with the electronics integrated circuit.

The sample rate of the MC3430 can be programmed from 1 to 128 samples / second. Even greater power savings can be achieved by taking advantage of event detection while the device is in a low power mode. Specific orientation and gesture conditions can trigger an interrupt to a remote MCU, allowing the processor to remain in a standby state until an event occurs. Alternatively, the device supports the reading of sample and event status via polling.

#### **FEATURES**

## Range, Sampling & Power

- ± 1.5g range
- 6,7, or 8-bit resolution
- 1 to 128 samples/sec
- Low power operation
  - 5 µA at 1 sample/sec
  - 30 μA at 128 sample/sec
  - Auto-wake/sniff modes

## **Event Detection**

- Low-noise architecture minimizes false triggering
- Tap, Shake, Drop
- Portrait or landscape orientation with programmable hysteresis
- Tilt detection in six orientations

## Simple System Integration

- I2C interface, up to 400 kHz
- 2 x 2 x 0.92 mm 12-pin package
- Pin-compatible to Bosch BMA2xx
- Single-chip 3D silicon MEMS
- 100µg / √Hz noise



# TABLE OF CONTENTS

| 1 |     | Orde | er Information                                | 5   |
|---|-----|------|-----------------------------------------------|-----|
| 2 |     | Fun  | ctional Block Diagram                         | 6   |
| 3 |     | Pac  | kaging and Pin Description                    | 7   |
|   | 3.1 |      | Package Outline                               | . 7 |
|   | 3.2 |      | Pin Description                               | 8   |
|   | 3.3 |      | Typical Application Circuit                   | 9   |
|   | 3.4 |      | Tape and Reel                                 | 10  |
| 4 |     | Spe  | cifications1                                  | 12  |
|   | 4.1 |      | Absolute Maximum Ratings                      | 12  |
|   | 4.2 |      | Sensor Characteristics                        | 13  |
|   | 4.3 |      | Electrical and Timing Characteristics         | 14  |
|   | 4.  | 3.1  | Electrical Power and Internal Characteristics | 14  |
|   | 4.  | 3.2  | I2C Electrical Characteristics1               | 15  |
|   | 4.  | 3.3  | I2C Timing Characteristics                    | 16  |
| 5 |     | Gen  | eral Operation1                               | 17  |
|   | 5.1 |      | Sensor Sampling                               | 17  |
|   | 5.2 |      | Offset and Gain Calibration                   | 18  |
| 6 |     | Оре  | erational States1                             | 19  |
| 7 |     | Оре  | erational State Flow                          | 20  |
|   | 7.1 |      | Sampling Rates2                               | 22  |
| 8 |     | Inte | rrupts                                        | 23  |
|   | 8.1 |      | Enabling and Clearing Interrupts2             | 23  |
|   | 8.2 |      | Interrupt Support                             | 24  |
|   | 8.3 |      | GINT Interrupt                                | 25  |
|   | 8.4 |      | Event Detection2                              | 26  |
| 9 |     | Orie | entation Detection                            | 27  |
|   | 9.1 |      | Orientation Event Filter2                     | 27  |
|   | 9.2 |      | Orientation Hysteresis2                       | 27  |
|   | 9.3 |      | Portrait/Landscape Events                     | 27  |
|   | 9.4 |      | Front/Back Events                             | 32  |
|   | 9.5 |      | Shake Detection                               | 34  |
|   | 9.6 |      | Drop Detection                                | 36  |

| 9.7   | Tap Detection                                            | 37 |
|-------|----------------------------------------------------------|----|
| 9.8   | Continuous Sampling                                      | 39 |
| 10 I2 | C Interface                                              | 40 |
| 10.1  | Physical Interface                                       | 40 |
| 10.2  | Timing                                                   | 40 |
| 10.3  | I2C Message Format                                       | 40 |
| 11 R  | egister Interface                                        | 42 |
| 11.1  | Register Summary                                         | 43 |
| 11.2  | XOUT, YOUT & ZOUT: X, Y & Z-Axis Accelerometer Registers | 45 |
| 11.3  | TILT: Status Register                                    | 46 |
| 11.4  | OPSTAT: Operational State Status Register                | 48 |
| 11.5  | SC: Sleep Counter Register                               | 49 |
| 11.6  | INTEN: Interrupt Enable Register                         | 50 |
| 11.7  | MODE: Register                                           | 51 |
| 11.8  | SAMPR: Sample Rate Register                              | 52 |
| 11.9  | TAPEN: Tap Detection Enable Register                     | 54 |
| 11.10 | TAPP: Tap Pulse Register                                 | 55 |
| 11.11 | DROP: Drop Event Control Register                        | 56 |
| 11.12 | SHDB: Shake Debounce Register                            | 57 |
| 11.13 | CHIPID: Chip Identification Register                     | 58 |
| 11.14 | X-Axis Offset Registers                                  | 59 |
| 11.15 | Y-Axis Offset Registers                                  | 60 |
| 11.16 | Z-Axis Offset Registers                                  | 61 |
| 11.17 | X-Axis Gain Registers                                    | 62 |
| 11.18 | Y-Axis Gain Registers                                    | 63 |
| 11.19 | Z-Axis Gain Registers                                    | 64 |
| 11.20 | SHAKE_TH: Shake Threshold Register                       | 65 |
| 11.21 | UD_Z_TH: Up/Down Z Axis Threshold Register               | 66 |
| 11.22 | UD_X_TH: Up/Down X Axis Threshold Register               | 67 |
| 11.23 | RL_Z_TH: Right/Left Z Axis Threshold Register            | 68 |
| 11.24 | RL_Y_TH: Right/Left Y Axis Threshold Register            | 69 |
| 11.25 | FB_Z_TH: Front/Back Z Axis Threshold Register            |    |
| 11.26 | DROP_TH: Drop Threshold Register                         | 71 |
| 11.27 | TAP TH: Tap Threshold Register                           | 72 |

| 11.2 | 28  | PCODE: Product Code                                           | . 73 |
|------|-----|---------------------------------------------------------------|------|
| 12   | Exa | ample MC3430 Configuration                                    | . 74 |
| 12.1 | 1   | Example: Tap Demo                                             | . 74 |
| 12.2 | 2   | Example: GINT Interrupt with Auto-Wake and Auto-Sniff Enabled | . 75 |
| 13   | Ind | ex of Tables                                                  | . 76 |
| 14   | Rev | vision History                                                | . 78 |
| 15   | Leg | gal                                                           | . 79 |

## 1 ORDER INFORMATION

| Part Number | Resolution | Order Number | Package | Shipping         |
|-------------|------------|--------------|---------|------------------|
| MC3430      | 8-bit      | MC3430       | VLGA-12 | Tape & Reel, 5Ku |

**Table 1. Order Information** 

## **2 FUNCTIONAL BLOCK DIAGRAM**



Figure 1. Block Diagram

## 3 PACKAGING AND PIN DESCRIPTION

## 3.1 PACKAGE OUTLINE







|        | DIMENSION (MM) |          |       |  |  |  |  |
|--------|----------------|----------|-------|--|--|--|--|
| SYMBOL | MIN.           | NOM.     | MAX.  |  |  |  |  |
| Α      | 0.85 0.92      |          | 1.00  |  |  |  |  |
| D      |                | 2.00 BSC |       |  |  |  |  |
| E      | 2.00 BSC       |          |       |  |  |  |  |
| е      | 0.5 BSC        |          |       |  |  |  |  |
| e1     | 0.5125 REF     |          |       |  |  |  |  |
| b      | 0.20           | 0.25     | 0.30  |  |  |  |  |
| L1     | 0.05           | 0.10     | 0.15  |  |  |  |  |
| L      | 0.225          | 0.275    | 0.325 |  |  |  |  |

Figure 2. Package Outline and Mechanical Dimensions

NOTE: Additional packaging information and device orientation can be found in Section <u>11.3</u> <u>TILT: Status Register</u>.

#### 3.2 PIN DESCRIPTION

| Pin | Name              | Function                          |  |  |
|-----|-------------------|-----------------------------------|--|--|
| 1   | NC                | No connect                        |  |  |
| 2   | SDA 1             | I2C serial data input/output      |  |  |
| 3   | DVDD              | I/O power supply                  |  |  |
| 4   | NC                | No connect                        |  |  |
| 5   | INTN <sup>2</sup> | Interrupt active LOW <sup>3</sup> |  |  |
| 6   | VPP               | Connect to GND                    |  |  |
| 7   | AVDD              | Analog power supply               |  |  |
| 8   | NC                | No Connect                        |  |  |
| 9   | GND               | Ground                            |  |  |
| 10  | TEST              | Optional probe pin                |  |  |
| 11  | NC                | No connect                        |  |  |
| 12  | SCL 1             | I2C serial clock input            |  |  |

**Table 2. Pin Description** 

## Notes:

- 1) This pin requires a pull-up resistor, typically 4.7k $\Omega$  to DVDD. Refer to I2C Specification for Fast-Mode devices. Higher resistance values can be used (typically done to reduce current leakage) but such applications are outside the scope of this datasheet.
- 2) This pin can be configured by software to operate either as an open-drain output or push-pull output ( $\underline{MODE: Register}$ ). If set to open-drain, then it requires a pull-up resistor, typically  $4.7k\Omega$  to DVDD.
- 3) INTN pin polarity is programmable in the MODE: Register.

## 3.3 TYPICAL APPLICATION CIRCUIT



NOTE<sup>1</sup>: Rp are typically  $4.7k\Omega$  pullup resistors to DVDD, per I2C specification. When DVDD is powered down, SDA and SCL will be driven low by internal ESD diodes. NOTE<sup>2</sup>: Attach typical  $4.7k\Omega$  pullup resistor if INTN is defined as open-drain.

Figure 3. Typical Application Circuit

In typical applications, the interface power supply may contain significant noise from external sources and other circuits which should be kept away from the sensor. Therefore, for some applications a lower-noise power supply might be desirable to power the AVDD pin.

## 3.4 TAPE AND REEL

Devices are shipped in reels, in standard cardboard box packaging. See Figure 4. MC3430 Tape Dimensions and Figure 5. MC3430 Reel Dimensions.



- Dimensions in mm.
- 10 sprocket hole pitch cumulative tolerance ±0.2
- Pocket position relative to sprocket hole measured as true position of pocket, not pocket hole.

Figure 4. MC3430 Tape Dimensions



• Dimensions in mm.

Figure 5. MC3430 Reel Dimensions

## **4 SPECIFICATIONS**

## 4.1 ABSOLUTE MAXIMUM RATINGS

Parameters exceeding the Absolute Maximum Ratings may permanently damage the device.

| Rating                                                  | Symbol                 | Minimum / Maximum<br>Value                       | Unit           |
|---------------------------------------------------------|------------------------|--------------------------------------------------|----------------|
| Supply Voltages                                         | Pins DVDD and AVDD     | -0.3 / +3.6                                      | V              |
| Acceleration, any axis, 100 μs                          | 9 мах                  | 10000                                            | g              |
| Ambient operating temperature                           | T <sub>OP</sub>        | -40 / +85                                        | <sub>0</sub> C |
| Storage temperature                                     | T <sub>STG</sub>       | -40 / +125                                       | 0C             |
| ESD human body model                                    | НВМ                    | ± 2000                                           | V              |
| Latch-up current at T <sub>op</sub> = 25 <sup>0</sup> C | I <sub>LU</sub>        | 100                                              | mA             |
| Input voltage to non-power pin                          | Pins INTN, SCL and SDA | -0.3 / (DVDD + 0.3) or 3.6<br>whichever is lower | V              |

**Table 3. Absolute Maximum Ratings** 

## 4.2 SENSOR CHARACTERISTICS

DVDD, AVDD = 2.8V,  $T_{op} = 25$   $^{\circ}C$  unless otherwise noted

| Parameter                                             | Conditions                     | Min | Тур    | Max | Unit               |
|-------------------------------------------------------|--------------------------------|-----|--------|-----|--------------------|
| Acceleration range                                    |                                |     | ±1.5   |     | g                  |
| Sensitivity                                           |                                |     | 85     |     | LSB/g              |
| Sensitivity Temperature<br>Coefficient <sup>1</sup>   | -40 ≤ T <sub>op</sub> ≤ +85 °C |     | ± 0.02 |     | %/ºC               |
| Zero-g Offset                                         |                                |     | ± 100  |     | mg                 |
| Zero-g Offset Temperature<br>Coefficient <sup>1</sup> | -40 ≤ T <sub>op</sub> ≤ +85 °C |     | ± 1    |     | mg/ <sup>0</sup> C |
| Noise Density <sup>1</sup>                            |                                |     | 100    |     | μg/√Hz             |
| Nonlinearity <sup>1</sup>                             |                                |     | 1      |     | % FS               |
| Cross-axis Sensitivity 1                              | Between any two axes           |     | 1      |     | %                  |

**Table 4. Sensor Characteristics** 

APS-048-0011v1.5

<sup>&</sup>lt;sup>1</sup> Values are based on device characterization, not tested in production.

## 4.3 ELECTRICAL AND TIMING CHARACTERISTICS

## 4.3.1 ELECTRICAL POWER AND INTERNAL CHARACTERISTICS

| Parameter                          | Conditions | Symbol | Min | Тур | Max | Unit |
|------------------------------------|------------|--------|-----|-----|-----|------|
| Supply voltage <sup>2</sup>        |            | AVDD   | 2.0 |     | 3.6 | V    |
| I/O voltage <sup>2</sup>           |            | DVDD   | 1.7 |     | 3.6 | V    |
| Sample Rate Tolerance <sup>3</sup> |            | Tclock | -5  |     | 5   | %    |

Test condition: AVDD = DVDD = 2.8V,  $T_{op} = 25$   $^{0}C$  unless otherwise noted

| Parameter         | Conditions      | Symbol             | Min | Тур  | Max | Unit |
|-------------------|-----------------|--------------------|-----|------|-----|------|
|                   | AVDD=2.0V       |                    |     | 1.6  |     |      |
| Standby current   | AVDD=2.8V       | I <sub>dd0</sub>   |     | 1.8  |     | μΑ   |
|                   | AVDD=3.6V       |                    |     | 2.0  |     |      |
| WAKE state supply | 1 sample/s      | I <sub>dd1</sub>   |     | 5    |     |      |
| current           | 128 samples / s | I <sub>dd128</sub> |     | 30   |     | μΑ   |
| Pad Leakage       | Per I/O pad     | I <sub>pad</sub>   | -1  | 0.01 | 1   | μΑ   |

**Table 5. Electrical Characteristics** 

<sup>&</sup>lt;sup>2</sup> Min and Max limits are hard limits without additional tolerance.

<sup>&</sup>lt;sup>3</sup> Values are based on device characterization, not tested in production.

## 4.3.2 I2C ELECTRICAL CHARACTERISTICS

| Parameter                                                                         | Symbol | Min       | Max      | Unit |
|-----------------------------------------------------------------------------------|--------|-----------|----------|------|
| LOW level input voltage                                                           | VIL    | -0.5      | 0.3*DVDD | V    |
| HIGH level input voltage                                                          | VIH    | 0.7*DVDD  | -        | V    |
| Hysteresis of Schmitt trigger inputs                                              | Vhys   | 0.05*DVDD | -        | V    |
| Output voltage, pin INTN, lol ≤ 2 mA                                              | Vol    | 0         | 0.4      | V    |
| Output voltage, pin invita, for 2 2 miles                                         | Voh    | 0         | 0.9*DVDD | V    |
| Output voltage, pin SDA (open drain),<br>Iol ≤ 1 mA                               | Vols   | -         | 0.1*DVDD | ٧    |
| Input current, pins SDA and SCL (input voltage between 0.1*DVDD and 0.9*DVDD max) | li     | -10       | 10       | μΑ   |
| Capacitance, pins SDA and SCL <sup>4</sup>                                        | Ci     | -         | 10       | pF   |

**Table 6. I2C Electrical and Timing Characteristics** 

## NOTES:

- If multiple slaves are connected to the I2C signals in addition to this device, only 1 pull-up resistor on each of SDA and SCL should exist. Also, care must be taken to not violate the I2C specification for capacitive loading.
- When DVDD is not powered and set to 0V, INTN, SDA and SCL will be held to DVDD plus the forward voltage of the internal static protection diodes, typically about 0.6V.
- When DVDD is disconnected from power or ground (e.g. Hi-Z), the device may become inadvertently powered up through the ESD diodes present on other powered signals.

15 / 79

<sup>&</sup>lt;sup>4</sup> Values are based on device characterization, not tested in production.

## 4.3.3 I2C TIMING CHARACTERISTICS



Figure 6. I2C Interface Timing

|                      |                                            |     | dard<br>ode | Fast | Mode |       |
|----------------------|--------------------------------------------|-----|-------------|------|------|-------|
| Parameter            | Description                                | Min | Max         | Min  | Max  | Units |
| f <sub>SCL</sub>     | SCL clock frequency                        | 0   | 100         | 0    | 400  | kHz   |
| t <sub>HD; STA</sub> | Hold time (repeated) START condition       | 4.0 | -           | 0.6  | _    | μs    |
| t <sub>LOW</sub>     | LOW period of the SCL clock                | 4.7 | _           | 1.3  | -    | μs    |
| t <sub>HIGH</sub>    | HIGH period of the SCL clock               | 4.0 | -           | 0.6  | -    | μs    |
| t <sub>SU;STA</sub>  | Set-up time for a repeated START condition | 4.7 | -           | 0.6  | -    | μs    |
| t <sub>HD;DAT</sub>  | Data hold time                             | 5.0 | -           | -    | -    | μs    |
| t <sub>SU;DAT</sub>  | Data set-up time                           | 250 | -           | 100  | _    | ns    |
| t <sub>SU;STO</sub>  | Set-up time for STOP condition             | 4.0 | -           | 0.6  | -    | μs    |
| t <sub>BUF</sub>     | Bus free time between a STOP and START     | 4.7 | -           | 1.3  | -    | μs    |

**Table 7. I2C Timing Characteristics** 

NOTE: Values are based on I2C Specification requirements, not tested in production.

See also Section 10.3 I2C Message Format.

## **5 GENERAL OPERATION**

The sampling rate range for the MC3430 can be set from 1 to 128 samples per second. The resulting sensor readings appear as signed 8-bit values. If 6-bit or 7-bit values are desired by a customer application, software should truncate LSBs from the 8-bit bit-field appropriately.

#### 5.1 SENSOR SAMPLING

In the WAKE state, acceleration data for X, Y, and Z axes is sampled at a rate between 1 and 128 samples/second. See Section 11.8 SAMPR: Sample Rate Register.

When the sample rate is set to 128 samples/second, the event detection logic runs at 256 Hz. At other sample rates the event detection logic runs at the sample rate.

The detectable acceleration range is from -1.5g to +1.5g.

In the lower power SNIFF state, acceleration data for X, Y, and Z axes is sampled at a reduced rate between 1 and 32 samples/second. See Section 11.8 SAMPR: Sample Rate Register.

Typically, a rate of about 20 to 50 samples per second is required to detect shake events in user-interface types of applications. Detecting tap events in these applications is best done at the rate of 64 to 128 samples per second. An event may be detected at any sampling rate, no matter how slow, however the trade-off is that at slower rates the events must be stronger to be detected.

The measurement data is stored in the XOUT, YOUT, and ZOUT registers in 2's complement format. Each sample is used to update the SHAKED, TAPD, DROPD, and BAFR and POLA orientation status bits in the <u>TILT: Status Register</u>. See Section <u>11.2 XOUT, YOUT & ZOUT: X, Y & Z-Axis Accelerometer Registers</u>.

| Resolution | Acceleration<br>Range | Value per<br>bit<br>(mg/LSB) | Full Scale<br>Negative<br>Reading | Full Scale<br>Positive<br>Reading | Comments                                                                                                                |
|------------|-----------------------|------------------------------|-----------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| 8-bit      | ± 1.5g                | ~11.7                        | 0x80<br>(-128)                    | 0x7F<br>(+127)                    | Signed 2's complement number, results in XOUT, YOUT, ZOUT. The MSB is the sign bit. (Integer interpretation also shown) |

Table 8. Summary of Resolution, Range, and Scaling

## 5.2 OFFSET AND GAIN CALIBRATION

Digital offset and gain calibration can be performed on the sensor, if necessary, in order to reduce the effects of post-assembly influences and stresses which may cause the sensor readings to be offset from their factory values. The register controls are described in Sections 11.14 through 11.19.

## **6 OPERATIONAL STATES**

The device has three states of operation: STANDBY (the default state after power-up), SNIFF, and WAKE, to provide a balance between power consumption and motion event detection.

The STANDBY state offers the lowest power consumption. In this state, the I2C interface is active and all register reads and writes are allowed. There is no event detection, sampling, or acceleration measurement in the STANDBY state. Internal clocking is halted. Complete access to the register set is allowed in this state, but interrupts cannot be serviced. The device defaults to the STANDBY state following power-up. The time to change states from STANDBY to another state is less than 10uSec and does not depend upon the sample rate.

# Registers can be written (and therefore thresholds and other settings changed) only when the device is in STANDBY state.

The SNIFF state offers low power consumption, event detection, and an auto-wake feature at a reduced sampling rate. The SNIFF state samples the accelerometer values at a slower rate than the WAKE state, typically done to save power.

The WAKE state offers the highest sampling rate and therefore the most precise motion event detection. The WAKE state also features an auto-sniff option that changes the device back to the lower-power SNIFF state if there is no motion activity for a timeout period. The sampling rate can vary from 1 sample/second to up to 128 samples/second, as described in <u>Table 12</u>. <u>WAKE State Sample Rates</u>.

The I2C interface allows write access to all registers only in the STANDBY state. In SNIFF and WAKE states, the only I2C register write access permitted is to the MODE: Register. Full read access is allowed in all states.

| State   | I2C Bus                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STANDBY | Device<br>responds to<br>I2C bus<br>(R/W)  | Device is powered; Registers can be accessed via I2C. Auto-wake is not enabled, so there is no event sniffing. Lowest power state. No interrupt generation, internal clocking disabled. Default power-on state.                                                                                                                                                                                                                                   |
| SNIFF   | Device<br>responds to<br>I2C bus<br>(Read) | Low power state, auto-wake is enabled. The device sniffs or checks for motion events at the sample rate specified by the bit-field SNIFFR. All registers except the MODE: Register are read-only.                                                                                                                                                                                                                                                 |
| WAKE    | Device<br>responds to<br>I2C bus<br>(Read) | WAKE state has the most choices for sample rate, allows for the continuous sampling and reading of sense data, and can make use of the sleep counter to detect periods of inactivity. During Low-Res sampling, the wake state sample rate is determined by the WAKER bit-field in the <a href="SAMPR: Sample Rate Register">SAMPR: Sample Rate Register</a> . All registers except the <a href="MODE: Register">MODE: Register</a> are read-only. |

**Table 9. Operational States** 

## 7 OPERATIONAL STATE FLOW

<u>Figure 7. Operational State Flow</u> shows the operational state flow for the device. When set to fully automatic mode (via the <u>MODE: Register</u>), the device will automatically transition between SNIFF and WAKE states as motion events or periods of inactivity are detected. Settings in the <u>MODE: Register</u> can be used to force the device into any of the three states. The device defaults to STANDBY following power-on.



Figure 7. Operational State Flow

Additionally, the operational state may be forced to a specific state by writing into the OPCON bits, as shown below. The operational state will stay in the mode specified until changed:

| Action                   | Setting         | Effect                                                                                                                                                   |
|--------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Force Wake State         | OPCON[1:0] = 01 | <ul><li>Switch to WAKE state and stay there</li><li>Switch to WAKER sampling rate</li></ul>                                                              |
| Force Sniff State        | OPCON[1:0] = 10 | <ul> <li>Switch to SNIFF state and stay there</li> <li>Switch to SNIFFR sample rate</li> <li>Ignore sleep counter timeout</li> <li>Ignore AWE</li> </ul> |
| Force Standby State      | OPCON[1:0] = 11 | <ul> <li>Switch to STANDBY state and stay there</li> <li>Disable sensor and event sampling</li> <li>Ignore AWE</li> </ul>                                |
| Set to auto-wake / sniff | OPCON[1:0] = 00 | See <u>Table 11</u> below                                                                                                                                |

**Table 10. Forcing Operational States** 

The truth table for the Operational State Flow is shown in <u>Table 11. Auto-Wake / Sniff Operational State Flow Truth Table</u>.

|     |     |              | SNIFF   | Current | Next    |                                                            |
|-----|-----|--------------|---------|---------|---------|------------------------------------------------------------|
| ASE | AWE | <b>EVENT</b> | TIMEOUT | State   | State   | Comments                                                   |
| Х   | 1   | Х            | x       | STANDBY | SNIFF   | Use AWE to move from                                       |
| Х   | 0   | Х            | x       | SNIFF   | STANDBY | STANDBY to SNIFF                                           |
| х   | 1   | 1            | X       | SNIFF   | WAKE    | Use AWE and EVENT to<br>move from SNIFF to<br>WAKE         |
| 1   | x   | X            | 1       | WAKE    | SNIFF   | Use ASE and SNIFF<br>TIMEOUT to move from<br>WAKE to SNIFF |

Table 11. Auto-Wake / Sniff Operational State Flow Truth Table

#### 7.1 SAMPLING RATES

The MC3430 features two sample rate selections, one for the WAKE state and one for the SNIFF state. The <u>SAMPR: Sample Rate Register</u> contains the controls for the WAKE state sample rate, set by the WAKER bit-field and the SNIFF state sample rate, set by the SNIFFR bit-field. The WAKE state sample rate can be set between 1 and 128 samples/second, as shown in <u>Table 12</u>. The SNIFF state sample rate can be set between 1 and 32 samples/second as shown in <u>Table 13</u>.

Sample measurements appear, one set per sample period, in the XOUT, YOUT, and ZOUT registers.

|       | WAKE<br>State |                                                                                                     |
|-------|---------------|-----------------------------------------------------------------------------------------------------|
| WAKER | Samples/      |                                                                                                     |
| [2:0] | Second        | Description                                                                                         |
| 000   | 128           |                                                                                                     |
| 001   | 64            |                                                                                                     |
| 010   | 32            | Wake State Sample Rate                                                                              |
| 011   | 16            | ·                                                                                                   |
| 100   | 8             | The wake state sample rate is determined by the WAKER bit-field in the SAMPR: Sample Rate Register. |
| 101   | 4             | the <u>SAMEN. Sample Nate Negister</u> .                                                            |
| 110   | 2             |                                                                                                     |
| 111   | 1             |                                                                                                     |

**Table 12. WAKE State Sample Rates** 

| SNIFFR<br>[1:0] | SNIFF<br>State<br>Samples/<br>Second | Description                                                          |
|-----------------|--------------------------------------|----------------------------------------------------------------------|
| 00              | 32                                   | Sniff State Sample Rate                                              |
| 01              | 16                                   | The SNIFF state sample rate is determined by the SNIFFR bit-field in |
| 10              | 8                                    | the <u>SAMPR: Sample Rate Register</u> .                             |
| 11              | 1                                    |                                                                      |

**Table 13. SNIFF State Sample Rates** 

## 8 INTERRUPTS

The sensor device utilizes output pin INTN to signal to an external microprocessor that an event has been sensed. The microprocessor would contain an interrupt service routine which would perform certain tasks after receiving this interrupt and reading the associated status bits, perhaps after the product was put into a certain orientation or had been tapped. The microprocessor would set up the registers in the sensor so that when a specific event is detected, the microprocessor would receive the interrupt and the interrupt service routine would be executed.

For products that will instead use polling, the method of reading sensor data would be slightly different. Instead of receiving an interrupt when an event occurs, the microprocessor must periodically poll the sensor and read status data while the INTN pin is not used. For most applications this is likely best done at the sensor sampling rate or faster. Note that at least one I2C STOP condition must be present between samples in order for the sensor to update the sample data registers.

In this case, the event detection bits (TAPD, SHAKED, DROPD) and associated interrupt enable bits in the <u>TILT: Status Register</u> must still be set up as if interrupts would occur in order for the status registers to be updated with proper data.

Although the INTN is not connected, the registers in the sensor will still contain valid status and so can be used by software to know the orientation of the product or if an event has occurred.

## 8.1 ENABLING AND CLEARING INTERRUPTS

The <u>INTEN</u>: Interrupt Enable Register determines which events generate interrupts. When an event is detected, it is masked with an interrupt enable bit in this register and the corresponding status bit is set in the <u>TILT</u>: <u>Status Register</u>. Multiple interrupt events might be reported at the same time in the <u>TILT</u>: <u>Status Register</u>, so software must interpret and prioritize the results.

The pin INTN is cleared during the next I2C bus cycle after the device ID has been recognized by the device.

When an interrupt is triggered, the first I2C read access to the device clears INTN pin. The condition (TAPD, SHAKED, DROPD) that generated the interrupt will remain held in the <u>TILT: Status Register</u> until it is read. Note that the orientation bit-fields POLA and BAFR are continuously updated (every sample) in the <u>TILT: Status Register</u> and are not held. Note that multiple interrupts may be active at the same time, and so a software routine reading the <u>TILT: Status Register</u> should account for this.

Any of the following interrupts can be enabled or disabled in the <u>INTEN</u>: <u>Interrupt Enable</u> <u>Register</u> and <u>DROP</u>: <u>Drop Event Control Register</u>.

- Front/Back Interrupt
- Up/Down/Left/Right (portrait / landscape) Interrupt
- Tap Detection Interrupt
- GINT (real-time motion tracking, generate interrupt each sample period)
- Shake on X-axis, Shake on Y-axis, and Shake on Z-axis
- Drop event detection

The <u>INTEN</u>: <u>Interrupt Enable Register</u> contains many of the interrupt enable bits. The drop interrupt enable bit DINT is located in the <u>DROP</u>: <u>Drop Event Control Register</u>.

## 8.2 INTERRUPT SUPPORT

The following table shows the relationship between motion events, interrupt enable bits, and the states the device may be in for determining when the device will generate an interrupt. No measurements or interrupts are generated in the STANDBY state.

| Motion Event                                              | Interrupt Enable<br>Bits | Wake              | Sniff | Standby |
|-----------------------------------------------------------|--------------------------|-------------------|-------|---------|
| Portrait/Landscape or<br>Front/Back orientation<br>change | FBINT = 1<br>PLINT = 1   | Yes               | Yes   | No      |
| Shake                                                     | SHINTX = 1               | Yes               | Yes   | No      |
|                                                           | SHINTY = 1               |                   |       |         |
|                                                           | SHINTZ = 1               |                   |       |         |
| Тар                                                       | TINT = 1                 | Yes               | No    | No      |
|                                                           |                          | Yes               | Yes   | No      |
| Drop                                                      | DINT = 1                 | Yes               | Yes   | No      |
| Auto-Sniff (no activity detected)                         | ASINT = 1                | Yes when<br>ASE=1 | No    | No      |
| Sample Update                                             | GINT = 1                 | Yes               | No    | No      |

**Table 14. Interrupt Support** 

## 8.3 GINT INTERRUPT

When enabled, the GINT interrupt triggers each time a sample acquisition is completed. The next I2C read operation rearms the interrupt for the next sample period but the condition (e.g. TAPD, SHAKED, DROPD) that generated the interrupt will remain held in the <u>TILT: Status Register</u> until it is read. The GINT interrupt frequency is determined by the WAKE state sample rate, 1 to 128 samples/seconds.

#### 8.4 EVENT DETECTION

The detection logic monitors and compares sensor outputs against the comparisons selected by the application software. Each type of event can be masked by a separate bit in the <a href="INTEN: Interrupt Enable Register">INTEN: Interrupt Enable Register</a>. The following table shows how the detection events are evaluated.

| Event               | X Axis               | Y Axis               | Z Axis                        |
|---------------------|----------------------|----------------------|-------------------------------|
| Up                  | Z  < (UD_Z_TH) and   |                      |                               |
|                     | X  > (UD_X_TH) and   |                      |                               |
|                     | X < 0 <sup>1</sup>   |                      |                               |
| Down                | Z  < (UD_Z_TH) and   |                      |                               |
|                     | X  > (UD_X_TH) and   |                      |                               |
|                     | X > 0 <sup>1</sup>   |                      |                               |
| Right               |                      | Z  < (RL_Z_TH) and   |                               |
|                     |                      | Y  > (RL_Y_TH) and   |                               |
|                     |                      | Y < 0 <sup>2</sup>   |                               |
| Left                |                      | Z  < (RL_Z_TH) and   |                               |
|                     |                      | Y  > (RL_Y_TH) and   |                               |
|                     |                      | Y > 0 <sup>2</sup>   |                               |
| Front               |                      |                      | Z > FB_Z_TH <sup>3</sup>      |
| Back                |                      |                      | Z < -1 * FB_Z_TH <sup>3</sup> |
| SHAKED <sup>4</sup> | X  > 1.3g ± SHAKE_TH | Y  > 1.3g ± SHAKE_TH | Z  > 1.3g ± SHAKE_TH          |
| DROPD 5             | X  < 0.5g ± DROP_TH  | Y  < 0.5g ± DROP_TH  | Z  < 0.5g ± DROP_TH           |
| TAPD <sup>6</sup>   | X  > TAP_TH          | Y  > TAP_TH          | Z  > TAP_TH                   |

**Table 15. Detection Logic Event Evaluation** 

 $<sup>^{1}</sup>$  Up/Down Z threshold is programmable from 0.425g to 1.172g, up/down X threshold is programmable from |X| to |X| + 0.747g.

<sup>&</sup>lt;sup>2</sup> Right/left Z threshold is programmable from 0.425g to 1.172g, right/left Y threshold is programmable from |Y| to |Y| + 0.747g.

<sup>&</sup>lt;sup>3</sup> Front/back Z threshold is programmable from 0.174g to 0.547g.

<sup>&</sup>lt;sup>4</sup> SHAKED event is triggered when any axis > SHAKE TH, programmable from 0.925g to 1.1672g.

<sup>&</sup>lt;sup>5</sup> DROPD event is triggered when condition (a)  $|X| + |Y| + |Z| < 0.5g + DROP_TH$  or condition (b)  $|X| < 0.5g \pm DROP_TH$  and  $|Y| < 0.5g \pm DROP_TH$  and  $|Z| < 0.5g \pm DROP_TH$ , this is user selectable. The range is from 0.125g to 0.872g.

<sup>&</sup>lt;sup>6</sup> TAPD event is triggered by  $|X| > TAP_TH$  or  $|Y| > TAP_TH$  g or  $|Z| > TAP_TH$ , where TAP\_TH is programmable and any combination of X, Y, and Z may be selected.

## 9 ORIENTATION DETECTION

The MC3430 allows an application to determine the orientation of the device. The current orientation of the device is reported as Left, Right, Up, Down, Front, and Back for each sampling period. This information generates the Portrait/Landscape status bits in the <u>TILT: Status Register</u>.

## 9.1 ORIENTATION EVENT FILTER

Application software can change the sensitivity of the POLA orientation detection by using the debounce filter settings FILT bit-field in the <u>SAMPR</u>: <u>Sample Rate Register</u>.

If FILT = 0, then new values for Left, Right, Up and Down are updated in the <u>TILT: Status</u> Register after each sampling period. If the FILT bit-field is set to another value, the device will update these values in the <u>TILT: Status Register</u> only after the orientation readings for Left, Right, Up and Down are the same for that number of consecutive sampling periods. The FILT bit-field has no effect on the reporting of Back / Front orientation status.

The debounce filter is reset after a mismatched reading or the orientation condition is met and the <u>TILT: Status Register</u> updated.

#### 9.2 ORIENTATION HYSTERESIS

Hysteresis can be added to portrait/landscape and front/back detection by modifying the default threshold offset values. See the specific sections below for more information.

#### 9.3 PORTRAIT/LANDSCAPE EVENTS

Portrait/landscape detection is a combination of left, right, up, and down events, also partially dependent upon Z sensor readings.

The default comparison angle for portrait/landscape is 45 degrees when evaluating differences between LEFT, RIGHT, UP, and DOWN, as long as the magnitude of Z is < 0.8g (default). See Figure 8.

By increasing the threshold values written to the <u>UD\_X\_TH: Up/Down X Axis Threshold</u> and <u>RL\_Y\_TH: Right/Left Y Axis Threshold</u>, hysteresis can be introduced to the angle of evaluation. These registers add a small offset to the default X and Y values and introduce additional margin in the portrait/landscape detection logic.

For most applications, the same value should be written to both registers.

When the device orientation is in the hysteresis region, the device will report orientation as "unknown". When this reading is reported, in order to implement a hysteresis effect for orientation, high-level software should use the last known portrait/landscape information.

In the example shown in Figure 9 the evaluation angle has been decreased to 40 degrees in each threshold, such that there is a 10 degree "deadband" or hysteresis-area between LEFT/RIGHT and DOWN/UP areas. The circle represents the acceleration in the Z axis, which has a default of 0.8g, or about a 33 degree tilt relative to the Z axis.





**Figure 8. Default Orientation Settings** 

Figure 9. Example Simple Orientation Hysteresis = 10 degrees

The Z threshold for each direction can also be adjusted, as shown in Figure 10. This has the effect of altering the angle relative to the Z axis which causes the orientation state to change.

Figure 11 shows an example of setting the UD\_Z\_TH and RL\_Z\_TH registers to different values, as well as setting the UD\_X\_TH and RL\_Y\_TH registers to different values. However for most applications the same value should be written to both registers in both cases.





Figure 10. Effect of Changing UD\_Z\_TH Threshold with Hysteresis = 10 degrees

Figure 11. Example of Complex Thresholds for Up/Down X, Right/Left Y, Up/Down Z & Right/Left Z

Table 16 summarizes the portrait/landscape event evaluation criteria. Some example threshold values and the corresponding trip angle and amount of hysteresis are shown in Table 17.

| Event | X Axis             | Y Axis             | Z Axis |
|-------|--------------------|--------------------|--------|
| Up    | Z  < (UD_Z_TH) and |                    |        |
|       | X  > (UD_X_TH) and |                    |        |
|       | X < 0              |                    |        |
| Down  | Z  < (UD_Z_TH) and |                    |        |
|       | X  > (UD_X_TH) and |                    |        |
|       | X > 0              |                    |        |
| Right |                    | Z  < (RL_Z_TH) and |        |
|       |                    | Y  > (RL_Y_TH) and |        |
|       |                    | Y < 0              |        |
| Left  |                    | Z  < (RL_Z_TH) and |        |
|       |                    | Y  > (RL_Y_TH) and |        |
|       |                    | Y > 0              |        |

Table 16. Portrait/Landscape Event Evaluation Criteria

| Registers UD_X_TH or RL_Y_TH Threshold Value | Trip Angle<br>(approx. degrees) | Resulting<br>Hysteresis<br>(approx. degrees) | Corresponding<br>g Value<br>(approximate) |
|----------------------------------------------|---------------------------------|----------------------------------------------|-------------------------------------------|
| 0x00                                         | 45                              | 0                                            | 0.72                                      |
| 0x10                                         | 43                              | 4                                            | 0.68                                      |
| 0x20                                         | 41                              | 8                                            | 0.66                                      |
| 0x30                                         | 39                              | 12                                           | 0.63                                      |
| 0x40                                         | 37                              | 16                                           | 0.61                                      |
| 0x50                                         | 36                              | 20                                           | 0.58                                      |
| 0x60                                         | 34                              | 24                                           | 0.55                                      |
|                                              |                                 |                                              |                                           |
| 0xFF                                         | 15                              | 64                                           | 0.26                                      |

Table 17. Some Approximate X and Y-axis Portrait/Landscape Evaluation Angles and Values

| Registers UD_Z_TH or RL_Z_TH Threshold Value | Trip Angle<br>(approx. degrees) | Corresponding g Value (approximate) |
|----------------------------------------------|---------------------------------|-------------------------------------|
| 0x80                                         | 67                              | 0.43                                |
| 0x90                                         | 64                              | 0.47                                |
|                                              |                                 |                                     |
| 0xE0                                         | 48                              | 0.71                                |
| 0xF0                                         | 45                              | 0.75                                |
| 0x00                                         | 40                              | 0.80                                |
| 0x10                                         | 36                              | 0.85                                |
| 0x20                                         | 32                              | 0.89                                |
|                                              |                                 |                                     |
| 0x70                                         | 9                               | 1.13                                |
| 0x7F                                         | 3                               | Max (~1.17)*                        |

Table 18. Some Approximate Z-axis Portrait/Landscape Evaluation Angles and Values

NOTE\*: Max values > 1.0g are possible, to cover offset variations.

Table 19 shows the orientation event conditions for the portrait/landscape detection hardware. The FILT bit-field in the <u>SAMPR: Sample Rate Register</u> can be used for the debouncing of portrait/landscape updates, as described above.

| POLA[2:0] | Left | Right | Down | Up | Description/Comments |
|-----------|------|-------|------|----|----------------------|
| 000       | 0    | 0     | 0    | 0  | Unknown              |
| 001       | 1    | 0     | 0    | 0  | Left/landscape       |
| 010       | 0    | 1     | 0    | 0  | Right/landscape      |
| 101       | 0    | 0     | 1    | 0  | Down/portrait        |
| 110       | 0    | 0     | 0    | 1  | Up/portrait          |

Table 19. Portrait/Landscape TILT: Status Register Assignments

## 9.4 FRONT/BACK EVENTS

The front/back detection compares ZOUT with a low g value, ranging from 0.174g to 0.547g, with the offset from 0.174g specified by the <u>FB\_Z\_TH: Front/Back Z Axis Threshold Register</u>. This equates to a range of approximately 55 degrees.

The BAFR bit-field is updated in the <u>TILT: Status Register</u> according to the front/back orientation sensed by the device. Additional hysteresis can be added to front/back detection by increasing the front/back Z axis threshold value located in the <u>FB\_Z\_TH: Front/Back Z Axis</u> Threshold Register.

When the front/back orientation of the device is in the deadband region, BAFR bit-field will report the orientation as "unknown". The default settings (0x00) equate to a range of approximately 25 degrees where the sensor will report BAFR = FRONT (or BACK). The maximum settings (0xFF) equate to about a 80 degree range. See Figure 12 and Figure 13.



Figure 12. Default Setting of FB\_Z\_TH for BAFR Readings



 $FB_Z_TH = 0xFF == 80^{\circ}$  (maximum, approx.)

Figure 13. Maximum setting of FB\_Z\_TH for BAFR Readings

The bit settings for the BAFR bit-field are shown in Table 20. Table 21 shows the front/back orientation evaluation criteria. Some example threshold values and the corresponding trip angles are shown in Table 22. All values are approximate and not tested in production.

| BAFR[1:0] | Status                                             |  |  |  |  |
|-----------|----------------------------------------------------|--|--|--|--|
| 00        | Unknown condition of front or back                 |  |  |  |  |
| 01        | 01 Front: Device is in orientation e. in Figure 20 |  |  |  |  |
| 10        | 10 Back: Device is in orientation f. in Figure 20  |  |  |  |  |
| 11        | Reserved                                           |  |  |  |  |

Table 20. BAFR Bit Assignments in the TILT: Status Register

| Event | X Axis | Y Axis | Z Axis           |
|-------|--------|--------|------------------|
| Front |        |        | Z > FB_Z_TH      |
| Back  |        |        | Z < -1 * FB_Z_TH |

Table 21. Front/Back Event Evaluation

|                 | FB_Z_TH Trip Angle |
|-----------------|--------------------|
| Threshold Value | (approx. degrees)  |
| 0x00            | 25                 |
| 0x10            | 28                 |
| 0x20            | 32                 |
| 0x30            | 35                 |
| 0x40            | 39                 |
| 0x50            | 42                 |
| 0x60            | 46                 |
| 0x70            | 49                 |
|                 |                    |
| 0xFF            | 80                 |

Table 22. Approximate Front/Back Evaluation Angles and Values

#### 9.5 SHAKE DETECTION

The threshold for detecting a shake event can be set to a range of values around a 1.3g baseline. The shake threshold can range from 0.925g to 1.672g. The value is a signed, 2's complement number. Resolution is approximately 2.9mg/bit.

A shake event will be triggered when high-g values are sensed for a sufficient number of samples.

<u>SHDB: Shake Debounce Register</u> can be set to count from 1 to 63 events before setting the SHAKED bit in the <u>TILT: Status Register</u>. Higher values yield longer evaluation periods. See Figure 14 and Figure 15.

Shake detection can be any combination of axes. To enable detection even when not using interrupts, set the corresponding SHINTX, SHINTY, or SHINTZ bit-fields in the <u>INTEN:</u> Interrupt Enable Register.

| Event | X Axis                      |    | Y Axis                    |    | Z Axis                 |
|-------|-----------------------------|----|---------------------------|----|------------------------|
| Shake | $ X  > +1.3g \pm Threshold$ | or | Y  > +1.3g ±<br>Threshold | or | Z  > +1.3g ± Threshold |

Table 23. SHAKE Event Evaluation (Baseline + Offset)



Shake Debounce Register == 4 but the sensed g value is above 1.3g + SHAKE\_TH for only 3 samples. Shake event is not detected.

Figure 14. Example Use of Shake Detection Hardware - Shake Not Detected



Shake Debounce Register == 4 and the sensed g value is above 1.3g + SHAKE\_TH for 5 samples. Shake event is detected.

Figure 15. Example Use of Shake Detection Hardware - Shake Detected.

#### 9.6 DROP DETECTION

Drop detection is defined as a low-g acceleration applied to all axes. Two modes of drop detection are supported:

Mode A: Drop detection is a summation of all 3 axes:

Drop is detected when:

Sum( mag(X) + mag(Y) + mag(Z) ) < 0.5g  $\pm$  DROP\_TH Threshold else Drop not detected;

Mode B: Drop detection is the logical AND of three comparisons:

Drop is detected when:

$$\label{eq:mag_problem} \begin{split} & \text{mag(X)} < 0.5\text{g} \pm \text{DROP\_TH Threshold and} \\ & \text{mag(Y)} < 0.5\text{g} \pm \text{DROP\_TH Threshold} \\ & \text{mag(Z)} < 0.5\text{g} \pm \text{DROP\_TH Threshold} \end{split}$$

else Drop not detected.

The typical drop threshold value is on the order of < 0.5g for all axes. The drop detection range is from 0.125g to 0.872g. The drop debounce value (bit-field DDB in the <u>DROP: Drop Event Control Register</u>) can filter from 1 to 8 consecutive events before setting the drop interrupt.

| Event X Axis   |                        |     | Y Axis                 |     | Z Axis                  |  |
|----------------|------------------------|-----|------------------------|-----|-------------------------|--|
| Drop Mode<br>A | Sum ( X                | +   | Y                      | +   | Z ) < 0.5g ±<br>DROP_TH |  |
| Drop Mode<br>B | X  < 0.5g ±<br>DROP_TH | and | Y  < 0.5g ±<br>DROP_TH | and | Z  < 0.5g ±<br>DROP_TH  |  |

**Table 24. Drop Event Evaluation** 

#### 9.7 TAP DETECTION

On-chip tap detection hardware allows the device to detect user events such as on-screen button presses. Tap detection can be enabled or disabled on each axis via the <u>TAPEN: Tap</u> Detection Enable Register.

To detect fast, impulse events like a tap, the <u>TAPP: Tap Pulse Register</u> should be written with a tap pulse parameter that sets the maximum number of sample periods that a TAPD event may exceed the threshold before it is ignored by the detection logic. Sensed values that are above the threshold for long periods of time typically do not correspond to tap events.

For example, setting the pulse value to 5 requires that the tap impulse exceed the threshold for at least 1 sample period and up to 5 sample periods. The tap detection hardware is rearmed after the sensed value is below the threshold. See the example in Figure 16 and Figure 17.



Tap Pulse Register == 5 but the sensed value is above the threshold for 10 samples. No tap is detected.

Figure 16. Example Use of Tap Detection Hardware - No Tap Detected



Tap Pulse Register == 5 and the sensed value is above the threshold for 3 samples. Tap is detected.

Figure 17. Example Use of Tap Detection Hardware - Tap Detected

The threshold value, set by writing the <u>TAP\_TH: Tap Threshold Register</u>, is an 8-bit unsigned number that species the threshold detection level for all tap events. This value is not an offset, but a magnitude which determines the minimum level for a valid tap event.

| Event | X Axis      | Y Axis      | Z Axis      |
|-------|-------------|-------------|-------------|
| Тар   | X  > TAP_TH | Y  > TAP_TH | Z  > TAP_TH |

**Table 25. Default Tap Event Evaluation** 

#### 9.8 CONTINUOUS SAMPLING

The device has the ability to read all sampled readings in a continuous sampling fashion. While sampling, the device updates the XOUT, YOUT, and ZOUT registers at a maximum rate of 128 samples / second, selectable by the SAMPR: Sample Rate Register.

An optional interrupt can be generated each time the sample registers have been updated (GINT interrupt bit in the <u>INTEN: Interrupt Enable Register</u>). See Sections <u>8.3</u> and <u>11.13</u> for GINT operation and options.

## 10 I2C INTERFACE

#### **10.1 PHYSICAL INTERFACE**

The I2C slave interface operates at a maximum speed of 400 kHz. The SDA (data) is an open-drain, bi-directional pin and the SCL (clock) is an input pin.

#### The device always operates as an I2C slave.

An I2C master initiates all communication and data transfers and generates the SCL clock that synchronizes the data transfer. The I2C device address is 0x4c (8-bit address 0x98).

The I2C interface remains active as long as power is applied to the DVDD and AVDD pins. In STANDBY state the device responds to I2C read and write cycles, but interrupts cannot be serviced or cleared. All registers can be written in the STANDBY state, but in SNIFF and WAKE only the MODE: Register can be modified.

Internally, the registers which are used to store samples are clocked by the sample clock gated by I2C activity. Therefore, in order to allow the device to collect and present samples in the sample registers at least one I2C STOP condition must be present between samples.

Refer to the I2C specification for a detailed discussion of the protocol. Per I2C requirements, SDA is an open drain, bi-directional pin. SCL and SDA each require an external pull-up resistor, typically  $4.7k\Omega$ . Refer also to Figure 3. Typical Application Circuit.

#### **10.2 TIMING**

See Section 4.3.3 I2C Timing Characteristics for I2C timing requirements.

#### 10.3 I2C MESSAGE FORMAT

The device uses the following general format for writing to the internal registers. The I2C master generates a START condition, and then supplies the device ID, 0x4C or 1001100. The 8<sup>th</sup> bit is the R/W# flag (write cycle = 0). The device pulls SDA low during the 9<sup>th</sup> clock cycle indicating a positive ACK. This means, from an 8-bit point of view of an external I2C master, writes should be written to address 0x98 and reads will occur by reading address 0x99.

The second byte is the 8-bit register address of the device to access, and the last byte is the data to write.



Figure 18. I2C Message Format, Write Cycle, Single Register Write

40 / 79

In a read cycle, the I2C master writes the device ID (R/W#=0) and register address to be read. The master issues a RESTART condition and then writes the device ID with the R/W# flag set to '1'. The device shifts out the contents of the register address.



Figure 19. I2C Message Format, Read Cycle, Single Register Read

The I2C master may write or read consecutive register addresses by writing or reading additional bytes after the first access. The device will internally increment the register address.

If an I2C burst read operation reads past register address 0x12 the internal address pointer "wraps" to address 0x03 and the contents of the <u>TILT: Status Register</u> are returned.

## 11 REGISTER INTERFACE

The device has a simple register interface which allows a MCU or I2C master to configure and monitor all aspects of the device. This section lists an overview of user programmable registers. By convention, Bit 0 is the least significant bit (LSB) of a byte register.

Acceleration data is contained in the single-byte per axis <u>XOUT, YOUT & ZOUT: X, Y & Z-Axis Accelerometer Registers</u>.

## 11.1 REGISTER SUMMARY

| Addr | Name   | Description                                        | Bit 7             | Bit 6             | Bit 5             | Bit 4             | Bit 3             | Bit 2             | Bit 1             | Bit 0             | POR<br>Value | R/<br>W <sup>5</sup> |
|------|--------|----------------------------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|--------------|----------------------|
| 0x00 | XOUT   | XOUT<br>Accelerometer<br>Register                  | XOUT<br>[7]       | XOUT<br>[6]       | XOUT<br>[5]       | XOUT<br>[4]       | XOUT<br>[3]       | XOUT<br>[2]       | XOUT<br>[1]       | XOUT<br>[0]       | 0x00         | R                    |
| 0x01 | YOUT   | YOUT<br>Accelerometer<br>Register                  | YOUT<br>[7]       | YOUT<br>[6]       | YOUT<br>[5]       | YOUT<br>[4]       | YOUT<br>[3]       | YOUT<br>[2]       | YOUT<br>[1]       | YOUT<br>[0]       | 0x00         | R                    |
| 0x02 | ZOUT   | ZOUT<br>Accelerometer<br>Register                  | ZOUT<br>[7]       | ZOUT<br>[6]       | ZOUT<br>[5]       | ZOUT<br>[4]       | ZOUT<br>[3]       | ZOUT<br>[2]       | ZOUT<br>[1]       | ZOUT<br>[0]       | 0x00         | R                    |
| 0x03 | TILT   | <u>Tilt Status</u><br><u>Register</u>              | SHAKED            | DROPD             | TAPD              | POLA<br>[2]       | POLA<br>[1]       | POLA<br>[0]       | BAFR<br>[1]       | BAFR<br>[0]       | 0x00         | R                    |
| 0x04 | OPSTAT | Operational State Status Register                  | ОТРА              | 0                 | Resv <sup>7</sup> | 0                 | 0                 | 0                 | OPSTAT<br>[1]     | OPSTAT<br>[0]     | 0x03         | R                    |
| 0x05 | SC     | Sleep Counter<br>Register                          | SC[7]             | SC[6]             | SC[5]             | SC[4]             | SC[3]             | SC[2]             | SC[1]             | SC[0]             | 0x00         | W                    |
| 0x06 | INTEN  | <u>Interrupt</u><br>Enable Register                | SHINTX            | SHINTY            | SHINTZ            | GINT              | ASINT             | TINT              | PLINT             | FBINT             | 0x00         | w                    |
| 0x07 | MODE   | Mode Register                                      | IAH               | IPP               | SCPS              | ASE               | AWE               | 06                | OPCON<br>[1]      | OPCON<br>[0]      | 0x03         | W                    |
| 0x08 | SAMPR  | Sample Rate<br>Register                            | FILT<br>[2]       | FILT<br>[1]       | FILT<br>[0]       | SNIFFR<br>[1]     | SNIFFR<br>[0]     | WAKER<br>[2]      | WAKER<br>[1]      | WAKER<br>[0]      | 0x00         | W                    |
| 0x09 | TAPEN  | Tap Detection<br>Enable Register                   | ZDA               | YDA               | XDA               | Resv <sup>7</sup> | 0x00         | w                    |
| 0x0A | TAPP   | <u>Tap Pulse</u><br><u>Register</u>                | Resv <sup>7</sup> | Resv <sup>7</sup> | Resv <sup>7</sup> | Resv <sup>7</sup> | TAPP<br>[3]       | TAPP<br>[2]       | TAPP<br>[1]       | TAPP<br>[0]       | 0x00         | w                    |
| 0x0B | DROP   | Drop Event Control Register                        | DROP_<br>MODE     | DINT              | Resv <sup>7</sup> | Resv <sup>7</sup> | Resv <sup>7</sup> | DROP_<br>DB[2]    | DROP_<br>DB[1]    | DROP_<br>DB[0]    | 0x00         | w                    |
| 0x0C | SHDB   | <u>Shake</u><br><u>Debounce</u><br><u>Register</u> | Resv <sup>7</sup> | Resv <sup>7</sup> | SHDB<br>[5]       | SHDB<br>[4]       | SHDB<br>[3]       | SHDB<br>[2]       | SHDB<br>[1]       | SHDB<br>[0]       | 0x00         | w                    |
| 0x0  | D-0x17 |                                                    |                   |                   | •                 | RESERV            | 'ED <sup>8</sup>  |                   |                   | •                 |              | •                    |
| 0x18 | CHIPID | <u>Chip ID</u><br><u>Register</u>                  | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 1                 | 0                 | 0x02         | R                    |
| 0x1  | 9-0x20 |                                                    |                   |                   |                   | RESERV            | 'ED <sup>8</sup>  |                   |                   |                   |              |                      |
| 0x21 | XOFFL  | X-Offset<br>LSB Register                           | XOFF[7]           | XOFF[6]           | XOFF[5]           | XOFF[4]           | XOFF[3]           | XOFF[2]           | XOFF[1]           | XOFF[0]           | Per<br>chip  | w                    |
| 0x22 | XOFFH  | X-Offset<br>MSB Register                           | XGAIN[8]          | Resv <sup>7</sup> | XOFF[13]          | XOFF[12]          | XOFF[11]          | XOFF[10]          | XOFF[9]           | XOFF[8]           | Per<br>chip  | W                    |
| 0x23 | YOFFL  | <u>Y-Offset</u><br><u>LSB Register</u>             | YOFF[7]           | YOFF[6]           | YOFF[5]           | YOFF[4]           | YOFF[3]           | YOFF[2]           | YOFF[1]           | YOFF[0]           | Per<br>chip  | W                    |

<sup>5</sup> 'R' registers are read-only, via external I2C access. 'W' registers are read-write, via external I2C access.
 <sup>6</sup> Software must always write a zero '0' to this bit.
 <sup>7</sup> Bits designated as 'Resv' are reserved for future use.
 <sup>8</sup> Registers designated as 'RESERVED' should not be accessed by software.

43 / 79

| Addr | Name         | Description                                         | Bit 7           | Bit 6             | Bit 5           | Bit 4               | Bit 3            | Bit 2           | Bit 1           | Bit 0           | POR<br>Value | R/<br>W <sup>5</sup> |
|------|--------------|-----------------------------------------------------|-----------------|-------------------|-----------------|---------------------|------------------|-----------------|-----------------|-----------------|--------------|----------------------|
| 0x24 | YOFFH        | <u>Y-Offset</u><br><u>MSB Register</u>              | YGAIN[8]        | Resv <sup>7</sup> | YOFF[13]        | YOFF[12]            | YOFF[11]         | YOFF[10]        | YOFF[9]         | YOFF[8]         | Per<br>chip  | w                    |
| 0x25 | ZOFFL        | Z-Offset<br>LSB Register                            | ZOFF[7]         | ZOFF[6]           | ZOFF[5]         | ZOFF[4]             | ZOFF[3]          | ZOFF[2]         | ZOFF[1]         | ZOFF[0]         | Per<br>chip  | w                    |
| 0x26 | ZOFFH        | Z-Offset<br>MSB Register                            | ZGAIN[8]        | Resv <sup>7</sup> | ZOFF[13]        | ZOFF[12]            | ZOFF[11]         | ZOFF[10]        | ZOFF[9]         | ZOFF[8]         | Per<br>chip  | w                    |
| 0x27 | XGAIN        | X Gain Register                                     | XGAIN[7]        | XGAIN[6]          | XGAIN[5]        | XGAIN[4]            | XGAIN[3]         | XGAIN[2]        | XGAIN[1]        | XGAIN[0]        | Per<br>chip  | w                    |
| 0x28 | YGAIN        | Y Gain Register                                     | YGAIN[7]        | YGAIN[6]          | YGAIN[5]        | YGAIN[4]            | YGAIN[3]         | YGAIN[2]        | YGAIN[1]        | YGAIN[0]        | Per<br>chip  | w                    |
| 0x29 | ZGAIN        | Z Gain Register                                     | ZGAIN[7]        | ZGAIN[6]          |                 |                     | ZGAIN[3]         | ZGAIN[2]        | ZGAIN[1]        | ZGAIN[0]        | Per<br>chip  | w                    |
| 0x2A |              |                                                     |                 |                   | RES             | SERVED <sup>8</sup> |                  |                 |                 |                 |              |                      |
| 0x2B | SHAKE<br>_TH | <u>Shake</u><br><u>Threshold</u><br><u>Register</u> | SHAKE<br>_TH[7] | SHAKE<br>_TH[6]   | SHAKE<br>_TH[5] | SHAKE<br>_TH[4]     | SHAKE<br>_TH[3]  | SHAKE<br>_TH[2] | SHAKE<br>_TH[1] | SHAKE<br>_TH[0] | 0x00         | w                    |
| 0x2C | UD_Z<br>_TH  | Up/Down Z Threshold Register                        | UD_Z<br>_TH[7]  | UD_Z<br>_TH[6]    | UD_Z<br>_TH[5]  | UD_Z<br>_TH[4]      | UD_Z<br>_TH[3]   | UD_Z<br>_TH[2]  | UD_Z<br>_TH[1]  | UD_Z<br>_TH[0]  | 0x00         | w                    |
| 0x2D | UD_X<br>_TH  | Up/Down X Threshold Register                        | UD_X<br>_TH[7]  | UD_X<br>_TH[6]    | UD_X<br>_TH[5]  | UD_X<br>_TH[4]      | UD_X<br>_TH[3]   | UD_X<br>_TH[2]  | UD_X<br>_TH[1]  | UD_X<br>_TH[0]  | 0x00         | w                    |
| 0x2E | RL_Z<br>_TH  | Right/Left Z Threshold Register                     | RL_Z<br>_TH[7]  | RL_Z<br>_TH[6]    | RL_Z<br>_TH[5]  | RL_Z<br>_TH[4]      | RL_Z<br>_TH[3]   | RL_Z<br>_TH[2]  | RL_Z<br>_TH[1]  | RL_Z<br>_TH[0]  | 0x00         | w                    |
| 0x2F | RL_Y<br>_TH  | Right/Left Y Threshold Register                     | RL_Y<br>_TH[7]  | RL_Y<br>_TH[6]    | RL_Y<br>_TH[5]  | RL_Y<br>_TH[4]      | RL_Y<br>_TH[3]   | RL_Y<br>_TH[2]  | RL_Y<br>_TH[1]  | RL_Y<br>_TH[0]  | 0x00         | w                    |
| 0x30 | FB_Z<br>_TH  | Front/Back Z Threshold Register                     | FB_Z<br>_TH[7]  | FB_Z<br>_TH[6]    | FB_Z<br>_TH[5]  | FB_Z<br>_TH[4]      | FB_Z<br>_TH[3]   | FB_Z<br>_TH[2]  | FB_Z<br>_TH[1]  | FB_Z<br>_TH[0]  | 0x00         | w                    |
| 0x31 | DROP<br>_TH  | <u>Drop</u><br><u>Threshold</u><br><u>Register</u>  | DROP<br>_TH[7]  | DROP<br>_TH[6]    | DROP<br>_TH[5]  | DROP<br>_TH[4]      | DROP<br>_TH[3]   | DROP<br>_TH[2]  | DROP<br>_TH[1]  | DROP<br>_TH[0]  | 0x00         | w                    |
| 0x32 | TAP<br>_TH   | <u>Tap</u><br><u>Threshold</u><br><u>Register</u>   | TAP<br>_TH[7]   | TAP<br>_TH[6]     | TAP<br>_TH[5]   | TAP<br>_TH[4]       | TAP<br>_TH[3]    | TAP<br>_TH[2]   | TAP<br>_TH[1]   | TAP<br>_TH[0]   | 0x00         | w                    |
| 0x33 | to 0x3A      |                                                     |                 |                   |                 | RESERV              | ′ED <sup>8</sup> |                 |                 |                 |              |                      |
| 0x3B | PCODE        | Product Code                                        | 0               | 0                 | 1               | 1                   | 1                | 0               | 0               | 1               | 0x39         | R                    |
| 0x3C | to 0x3F      |                                                     |                 |                   |                 | RESERV              | 'ED <sup>8</sup> |                 |                 |                 |              |                      |

Table 26. Register Summary 9

44 / 79

 $<sup>^{9}</sup>$  No registers are updated with new event status or samples while a I2C cycle is in process.

## 11.2 XOUT, YOUT & ZOUT: X, Y & Z-AXIS ACCELEROMETER REGISTERS

Accelerometer measurements are stored in the XOUT, YOUT, and ZOUT registers. The measurements are in signed 2's complement format. The range is always  $\pm$  1.5g. XOUT[7] is the sign bit. If 6-bit or 7-bit values are desired by a customer application, software should truncate the 8-bit bit-field appropriately.

| Addr | Name | Description                       | Bit 7       | Bit 6       | Bit 5       | Bit 4       | Bit 3       | Bit 2       | Bit 1       | Bit 0       | POR<br>Value | R/W |
|------|------|-----------------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|--------------|-----|
| 0x00 | хоит | XOUT<br>Accelerometer<br>Register | XOUT<br>[7] | XOUT<br>[6] | XOUT<br>[5] | XOUT<br>[4] | XOUT<br>[3] | XOUT<br>[2] | XOUT<br>[1] | XOUT<br>[0] | 0x00         | R   |
| 0x01 | YOUT | YOUT<br>Accelerometer<br>Register | YOUT<br>[7] | YOUT<br>[6] | YOUT<br>[5] | YOUT<br>[4] | YOUT<br>[3] | YOUT<br>[2] | YOUT<br>[1] | YOUT<br>[0] | 0x00         | R   |
| 0x02 | ZOUT | ZOUT<br>Accelerometer<br>Register | ZOUT<br>[7] | ZOUT<br>[6] | ZOUT<br>[5] | ZOUT<br>[4] | ZOUT<br>[3] | ZOUT<br>[2] | ZOUT<br>[1] | ZOUT<br>[0] | 0x00         | R   |

**Table 27. Accelerometer Value Registers** 

#### 11.3 TILT: STATUS REGISTER

This register contains bits which are set when a motion event is detected. Each event has a corresponding interrupt enable which can mask any combination of events. The event detection bits (SHAKED, DROPD, TAPD) remain held until the register is read by the I2C interface. Note that the orientation bit-fields POLA and BAFR are continuously updated (every sample) in the TILT: Status Register and are not held. Note that multiple interrupts may be active at the same time, and so a software routine reading the TILT: Status Register should account for this. Refer to Figure 20. Package Orientation and Figure 21. Package Axis Reference.

| Addr | Name | Description             | Bit 7  | Bit 6 | Bit 5 | Bit 4       | Bit 3       | Bit 2       | Bit 1       | Bit 0       | POR<br>Value | R/<br>W |
|------|------|-------------------------|--------|-------|-------|-------------|-------------|-------------|-------------|-------------|--------------|---------|
| 0x03 | TILT | Tilt Status<br>Register | SHAKED | DROPD | TAPD  | POLA<br>[2] | POLA<br>[1] | POLA<br>[0] | BAFR<br>[1] | BAFR<br>[0] | 0x00         | R       |

| BAFR[1:0] | Back or Front  00: Unknown condition of front or back  01: Front – Device is in orientation e in Figure 20. Package Orientation.  10: Back – Device is in orientation f in Figure 20. Package Orientation.  11: Reserved                                                                                                                                                                                                 |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| POLA[2:0] | Portrait or Landscape 000: Unknown condition of up, down, left or right 001: Left – Device is in orientation b in Figure 20. Package Orientation. 010: Right – Device is in orientation c in Figure 20. Package Orientation. 011: Reserved 100: Reserved 101: Down – Device is in orientation d in Figure 20. Package Orientation. 110: Up – Device is in orientation a in Figure 20. Package Orientation. 111: Reserved |
| TAPD      | 0: Tap event not detected 1: Tap event detected                                                                                                                                                                                                                                                                                                                                                                          |
| DROPD     | 0: Drop event not detected 1: Drop event detected                                                                                                                                                                                                                                                                                                                                                                        |
| SHAKED    | 0: Shake event not detected 1: Shake event detected                                                                                                                                                                                                                                                                                                                                                                      |

**Table 28. TILT Status Register Settings** 



Figure 20. Package Orientation



Figure 21. Package Axis Reference

#### 11.4 OPSTAT: OPERATIONAL STATE STATUS REGISTER

The Operational State status register reports which operational state the device is in, either SNIFF, WAKE or STANDBY as shown in <u>Table 29</u>. <u>Operational State Status Register</u>.

| Addr | Name   | Description                       | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1         | Bit 0         | POR<br>Value | R/<br>W |
|------|--------|-----------------------------------|-------|-------|-------|-------|-------|-------|---------------|---------------|--------------|---------|
| 0x04 | OPSTAT | Operational State Status Register | ОТРА  | 0     | Resv  | 0     | 0     | 0     | OPSTAT<br>[1] | OPSTAT<br>[0] | 0x03         | R       |

| OPSTAT[1:0] | Sampling State Register Status, Wait State Register Status 00: Device is in auto-wake/auto-sniff mode 01: Device is in WAKE state, sample rate defined by WAKER[2:0] is active 10: Device is in SNIFF state, sample rate defined by SNIFFR[1:0] is active 11: Device is in STANDBY state, no sampling |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Resv        | Reserved                                                                                                                                                                                                                                                                                              |
| ОТРА        | One-time Programming (OTP) activity status  0: Internal memory is idle and the device is ready for use  1: Internal memory is active and the device is not yet ready for use                                                                                                                          |

Table 29. Operational State Status Register

#### 11.5 SC: SLEEP COUNTER REGISTER

If the device is in WAKE state, the sleep counter counts down during periods of inactivity. Inactivity is defined as no detectable motion events as masked by the interrupt enable register. If there are no interrupts during the WAKE state, the sleep counter will timeout.

The sleep counter has two ranges of timeout values. If set, the SCPS prescaler bit in the MODE: Register enables an extended set of timeout values.

If auto-sniff mode (ASE=1) is enabled, the sleep counter decrements if there is no detectable motion during the timeout period. If the sleep counter reaches 0, the device transitions to the SNIFF state. If the auto-wake feature (AWE=1) is enabled, the device remains in the SNIFF state and begins sampling at the reduced sample rate. If AWE=0, the device transitions to the STANDBY state.

| Addr | Name | Description               | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|------|---------------------------|-------|-------|-------|-------|-------|-------|-------|-------|--------------|---------|
| 0x05 | SC   | Sleep Counter<br>Register | SC[7] | SC[6] | SC[5] | SC[4] | SC[3] | SC[2] | SC[1] | SC[0] | 0x00         | w       |

**Table 30. Sleep Counter Register Settings** 

The sleep counter is decremented by the current sampling rate. Table 31 shows the relationship between the current sampling rate and the sleep counter timeout value. All values are approximate.

|               | SCP        | S = 0     | SCP       | S = 1     |
|---------------|------------|-----------|-----------|-----------|
| WAKER Setting | Min (mSec) | Max (sec) | Min (sec) | Max (sec) |
| 1             | 1000       | 256       | 16        | 4096      |
| 2             | 500        | 128       | 8         | 2048      |
| 4             | 250        | 64        | 4         | 1024      |
| 8             | 125        | 32        | 2         | 512       |
| 16            | 62.5       | 16        | 1         | 256       |
| 32            | 31.3       | 8         | 0.5       | 128       |
| 64            | 15.6       | 4         | 0.3       | 64        |
| 128           | 7.8        | 2         | 0.1       | 32        |

**Table 31. Sleep Counter Timeout Settings** 

#### 11.6 INTEN: INTERRUPT ENABLE REGISTER

The interrupt enable register enables or disables interrupts on various motion or auto-sniff events. If the corresponding interrupt enable bit is set, a matching event will generate an interrupt transition on the external interrupt pin, INTN. To enable the drop interrupt, set the DINT control bit in the DROP: Drop Event Control Register.

When an interrupt is triggered, the first I2C access to the device will clear the external interrupt pin, but the condition (TAPD, SHAKED, DROPD) that generated the interrupt will remain held in the <u>TILT</u>: <u>Status Register</u> until it is read. Note that the orientation bit-fields POLA and BAFR are continuously updated (every sample) in the <u>TILT</u>: <u>Status Register</u> and are not held.

| Addr | Name  | Description                  | Bit 7  | Bit 6  | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|-------|------------------------------|--------|--------|--------|-------|-------|-------|-------|-------|--------------|---------|
| 0x06 | INTEN | Interrupt Enable<br>Register | SHINTX | SHINTY | SHINTZ | GINT  | ASINT | TINT  | PLINT | FBINT | 0x00         | W       |

|           | Front / Back Interrupt                                                                    |
|-----------|-------------------------------------------------------------------------------------------|
| FBINT     | 0: Disable interrupt on front/back position change                                        |
|           | 1: Enable interrupt on front/back position change                                         |
|           | Portrait / Landscape Interrupt                                                            |
| PLINT     | 0: Disable interrupt on up/down/left/right position change                                |
|           | 1: Enable interrupt on up/down/left/right position change                                 |
|           | Tap Interrupt                                                                             |
| TINT      | 0: Disable interrupt on tap detection                                                     |
|           | 1: Enable interrupt on tap detection                                                      |
|           | Auto-Sniff Interrupt                                                                      |
| ASINT     | 0: Disable interrupt on exiting auto-sniff mode                                           |
|           | 1: Enable interrupt on exiting auto-sniff mode                                            |
|           | Generate Interrupt                                                                        |
|           | 0: Disable automatic interrupt after each measurement                                     |
| GINT      | 1: Enable automatic interrupt after each measurement is updated in XOUT, YOUT,            |
|           | or ZOUT. The interrupt occurs for each measurement, not value change. See                 |
|           | Section <u>8.3</u> .                                                                      |
|           | Shake Interrupt, X-axis                                                                   |
| SHINTX    | 0: Disable X-axis interrupt, SHAKED is not set in <u>TILT: Status Register</u> upon event |
|           | 1 : Enable X-axis interrupt, SHAKED is set in TILT: Status Register upon event            |
|           | Shake Interrupt, Y-axis                                                                   |
| SHINTY    | 0: Disable Y-axis interrupt, SHAKED bit is not set in <u>TILT: Status Register</u> upon   |
| Or mitter | event                                                                                     |
|           | 1 : Enable Y-axis interrupt, SHAKED bit is set in <u>TILT: Status Register</u> upon event |
|           | Shake Interrupt, Z-axis                                                                   |
| SHINTZ    | 0: Disable Z-axis interrupt, SHAKED bit is not set in TILT: Status Register upon          |
| 01111112  | event                                                                                     |
|           | 1 : Enable Z-axis interrupt, SHAKED bit is set in TILT: Status Register upon event        |

**Table 32. Interrupt Enable Register Settings** 

#### 11.7 MODE: REGISTER

The MODE register controls the active operating state of the device. This register can be written from any operational state (STANDBY, SNIFF, WAKE). Setting the OPCON bits to 00 allows the device to operate in auto-wake/sniff mode and automatically transition between WAKE and SNIFF when auto-wake (AWE) and auto-sniff (ASE) are enabled.

| Addr | Name | Description   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1        | Bit 0        | POR<br>Value | R/<br>W |
|------|------|---------------|-------|-------|-------|-------|-------|-------|--------------|--------------|--------------|---------|
| 0x07 | MODE | Mode Register | IAH   | IPP   | SCPS  | ASE   | AWE   | 0*    | OPCON<br>[1] | OPCON<br>[0] | 0x03         | W       |

NOTE\*: Software must always write a zero '0' to Bit 2.

| OPCON<br>[1:0] | _                                              | gs. The device ons between WAKE and upon events or timeouts. tate and remain there eate and remain there BY state and remain | Set Device Operational State.<br>WAKE, SNIFF or STANDBY                                                                                |  |  |  |  |
|----------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| AWE            | 0: Disable auto-<br>wake                       | Specified by the Sinfer difficient when the device exits the                                                                 |                                                                                                                                        |  |  |  |  |
| AVVL           | 1: Enable auto-<br>wake                        | specified by WAKER bit                                                                                                       | ce will switch to the samples per second field. The AWE bit also determines if the the STANDBY state to the SNIFF state                |  |  |  |  |
|                | 0: Disable auto-sniff                          | the WAKER bit-field.                                                                                                         | device uses the sample rate specified in When the device exits the WAKE state r timeout, it will switch to the sample rate             |  |  |  |  |
| ASE            | 1: Enable auto-sniff                           | specified by the SNIF device transitions from                                                                                | FR bit-field if AWE = 1. If AWE = 0, the the SNIFF state to STANDBY. If ASE=0, where WAKE state and not transition to SNIFF or STANDBY |  |  |  |  |
|                | 0: Sleep counter pres                          | scaler is divide-by-1                                                                                                        | Sleep Counter Prescaler This bit is the sleep counter prescaler                                                                        |  |  |  |  |
| SCPS           | 1: Sleep counter pres<br>(enable long range sl |                                                                                                                              | enable. If the bit is '1', the sleep counter timeout is 16 times larger.                                                               |  |  |  |  |
| IPP            | 0: Interrupt pin INTN and requires an exter    | is open drain (default)<br>rnal pull-up to AVDD.<br>is push-pull. No external                                                | Interrupt Push Pull                                                                                                                    |  |  |  |  |
| IAH            | 0: Interrupt pin INTN 1: Interrupt pin INTN    |                                                                                                                              | Interrupt Active High                                                                                                                  |  |  |  |  |

**Table 33. Mode Register Functionality** 

#### 11.8 SAMPR: SAMPLE RATE REGISTER

This register sets the sample rate during the WAKE and SNIFF states. The WAKE state sample rate is set in bit-field WAKER and the SNIFF state rate is set in bit-field SNIFFR. Measurements are updated to the XOUT, YOUT, and ZOUT registers at the specified sample rate. For tap detection, it is recommended to set the WAKER register to the maximum 128 samples/second.

The contents of XOUT, YOUT, and ZOUT are updated continuously with new sample data regardless of whether or not their values have been read out over the I2C interface.

If the auto-wake feature (AWE=1 in the <u>MODE: Register</u>) is enabled, the device will continue to look for motion events while in the SNIFF state, but at a reduced sample rate. The following table shows the possible reduced sample rate values. Note that the auto-wake bit must be enabled for the reduced sample rate to take affect while the device is dozing.

The FILT bit-field provides an event filter can be used to identify when anywhere from 2 to 8 samples match the orientation before detection is valid for portrait / landscape orientation changes.

| Addr | Name  | Description             | Bit 7       | Bit 6       | Bit 5       | Bit 4         | Bit 3         | Bit 2        | Bit 1        | Bit 0        | POR<br>Value | R/<br>W |
|------|-------|-------------------------|-------------|-------------|-------------|---------------|---------------|--------------|--------------|--------------|--------------|---------|
| 0x08 | SAMPR | Sample Rate<br>Register | FILT<br>[2] | FILT<br>[1] | FILT<br>[0] | SNIFFR<br>[1] | SNIFFR<br>[0] | WAKER<br>[2] | WAKER<br>[1] | WAKER<br>[0] | 0x00         | w       |

| WAKER<br>[2:0] | WAKE Sample Rate<br>(Samples/Second) |
|----------------|--------------------------------------|
| 000            | 128                                  |
| 001            | 64                                   |
| 010            | 32                                   |
| 011            | 16                                   |
| 100            | 8                                    |
| 101            | 4                                    |
| 110            | 2                                    |
| 111            | 1                                    |

| SNIFFR<br>[1:0] | SNIFF Sample Rate (Samples/Second) |
|-----------------|------------------------------------|
| 00              | 32                                 |
| 01              | 16                                 |
| 10              | 8                                  |
| 11              | 1                                  |

Table 34. Wake/Sniff Sample Rate Settings

The FILT bit-field allows for the debouncing of portrait/landscape events as reported in the <u>TILT: Status Register</u>. The POLA bit-field in the <u>TILT: Status Register</u> must match for the specified number of sample periods in the FILT bit-field before the POLA bit-field in the <u>TILT:</u> Status Register is updated, noting that a change in orientation was detected.

| FILT[2:0] | Tilt Debounce<br>Matching<br>Samples (n) | Description                                                                                                                                       |
|-----------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 000       | n/a                                      | Tilt debounce filtering is disabled. The device updates portrait/landscape status at every sample, at the rate set by bit-fields WAKER or SNIFFR. |
| 001       | 2                                        |                                                                                                                                                   |
| 010       | 3                                        |                                                                                                                                                   |
| 011       | 4                                        | Event Filter                                                                                                                                      |
| 100       | 5                                        | 'n' measurement samples at the rate set by WAKER or SNIFFR must match before the device updates the portrait/                                     |
| 101       | 6                                        | landscape status in the TILT: Status Register.                                                                                                    |
| 110       | 7                                        |                                                                                                                                                   |
| 111       | 8                                        |                                                                                                                                                   |

**Table 35. Tilt Debounce Filter Settings** 

#### 11.9 TAPEN: TAP DETECTION ENABLE REGISTER

This register allows individual tap/pulse detection on each axis. Setting XDA, YDA, or ZDA adds the corresponding axis to tap event detection. See also Section <u>9.7 Tap Detection</u>.

| Addr | Name  | Description                      | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|-------|----------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|--------------|---------|
| 0x09 | TAPEN | Tap Detection<br>Enable Register | ZDA   | YDA   | XDA   | Resv  | Resv  | Resv  | Resv  | Resv  | 0x00         | W       |

| XDA | Disable Tap detection on X-axis     Enable Tap detection on X-axis |
|-----|--------------------------------------------------------------------|
| YDA | Disable Tap detection on Y-axis     Enable Tap detection on Y-axis |
| ZDA | Disable Tap detection on Z-axis     Enable Tap detection on Z-axis |

**Table 36. TAPEN Register Settings** 

#### 11.10 TAPP: TAP PULSE REGISTER

This value sets the number of samples for which a tap pulse must exceed the TAP\_TH threshold before it is rejected as not a tap event. If the values detected by the sensor exceed the TAP\_TH threshold for longer than the reject count, no tap event is detected and the interrupt is not set. See also Section <u>9.7 Tap Detection</u>.

| Addr | Name | Description           | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3       | Bit 2       | Bit 1       | Bit 0       | POR<br>Value | R/<br>W |
|------|------|-----------------------|-------|-------|-------|-------|-------------|-------------|-------------|-------------|--------------|---------|
| 0x0A | ТАРР | TAP Pulse<br>Register | Resv  | Resv  | Resv  | Resv  | TAPP<br>[3] | TAPP<br>[2] | TAPP<br>[1] | TAPP<br>[0] | 0x00         | w       |

| TAPP<br>[3:0] | Tap<br>Detection<br>Sample<br>Periods (n) | Description                                                                                                                                       |
|---------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0           | 1                                         |                                                                                                                                                   |
| 0x1           | 2                                         | This tap detection filtering requires the sensed values to exceed the                                                                             |
| 0x2           | 3                                         | TAP_TH threshold level for at least 1 sample and less than n sample periods. When they have, the sensor will set TAPD bit in the <u>TILT:</u>     |
| 0x3           | 4                                         | Status Register. In addition, if the TINT tap interrupt is enabled in the INTEN: Interrupt Enable Register then an interrupt will be generated by |
|               | 5 ≤ n ≤ 15                                | the device.                                                                                                                                       |
| 0xF           | 16                                        |                                                                                                                                                   |

**Table 37. TAPP Tap Pulse Register Settings** 

## 11.11 DROP: DROP EVENT CONTROL REGISTER

| Addr | Name | Description                    | Bit 7         | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2          | Bit 1          | Bit 0          | POR<br>Value | R/<br>W |
|------|------|--------------------------------|---------------|-------|-------|-------|-------|----------------|----------------|----------------|--------------|---------|
| 0x0B | DROP | Drop Event Control<br>Register | DROP_<br>MODE | DINT  | Resv  | Resv  | Resv  | DROP_<br>DB[2] | DROP_<br>DB[1] | DROP_<br>DB[0] | 0x00         | w       |

| DROP_DB[2:0] | Drop Debounce 000: 1 drop event 001: 2 adjacent drop events 010: 3 adjacent drop events : 4 ≤ n ≤ 7 adjacent drop events 111: 8 adjacent drop events                                                                                                    | Drop event debounce value, the number of drop events detected must reach this count for the final event to be valid. |  |  |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| DINT         | Drop Interrupt  0: Disable drop event interrupt                                                                                                                                                                                                         | The DROPD bit in the <u>TILT: Status</u> Register will be set upon event                                             |  |  |  |  |  |
|              | 1: Enable drop event interrupt                                                                                                                                                                                                                          | occurrence regardless of this bit setting.                                                                           |  |  |  |  |  |
| DROP_MODE    | 1: Enable drop event interrupt occurrence regardless of this bit setting  Drop Mode 0: Mode A: Drop detection is a summation of all 3 axes:  Drop is detected when:  Sum( mag(X) + mag(Y) + mag(Z) ) < 0.5g ± DROP_TH Threshold else Drop not detected; |                                                                                                                      |  |  |  |  |  |
|              | mag(Z) < 0.5g ± DROP_TH Thres else Drop not detected.                                                                                                                                                                                                   | noia                                                                                                                 |  |  |  |  |  |

**Table 38. Drop Event Control Register Settings** 

#### 11.12 SHDB: SHAKE DEBOUNCE REGISTER

The shake debounce register allows a 1 to 63 event count to be required before a valid shake event is detected or an interrupt is generated. The debounce value applies to all 3-axes.

| Addr | Name | Description                | Bit 7 | Bit 6 | Bit 5       | Bit 4       | Bit 3       | Bit 2       | Bit 1       | Bit 0       | POR<br>Value | R/<br>W |
|------|------|----------------------------|-------|-------|-------------|-------------|-------------|-------------|-------------|-------------|--------------|---------|
| 0x0C | SHDB | Shake Debounce<br>Register | Resv  | Resv  | SHDB<br>[5] | SHDB<br>[4] | SHDB<br>[3] | SHDB<br>[2] | SHDB<br>[1] | SHDB<br>[0] | 0x00         | W       |

| SHDB[5:0] | Adjacent Shake<br>Events (n) | Description                                                                                                                               |
|-----------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 0x01      | 1                            | Shake detection debounce filtering requires n adjacent shake                                                                              |
| 0x02      | 2                            | detection events in order to trigger a shake event and set the                                                                            |
| 0x03      | 3                            | SHAKED bit in the <u>TILT: Status Register</u> . In addition, if the SHINTX, SHINTY or SHINTZ bits are set in the <u>INTEN: Interrupt</u> |
|           | 4 ≤ n ≤ 62                   | Enable Register and that event occurs, then an interrupt will be                                                                          |
| 0x3F      | 63                           | generated by the device.                                                                                                                  |

Table 39. SH\_DB Shake Debounce Register Settings

## 11.13 CHIPID: CHIP IDENTIFICATION REGISTER

This register returns 0x02.

| Addı | Name   | Description      | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|--------|------------------|-------|-------|-------|-------|-------|-------|-------|-------|--------------|---------|
| 0x18 | CHIPID | Chip ID Register | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0x02         | R       |

#### 11.14 X-AXIS OFFSET REGISTERS

This register contains a signed 2's complement 14-bit value applied as an offset adjustment to the output of the sensor values, prior to being sent to the OUT registers. The Power-On-Reset value for each chip is unique and is set as part of factory calibration. If necessary, this value can be overwritten by software.

| Addr | Name  | Description              | Bit 7    | Bit 6   | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1   | Bit 0   | POR<br>Value | R/<br>W |
|------|-------|--------------------------|----------|---------|----------|----------|----------|----------|---------|---------|--------------|---------|
| 0x21 | XOFFL | X-Offset<br>LSB Register | XOFF[7]  | XOFF[6] | XOFF[5]  | XOFF[4]  | XOFF[3]  | XOFF[2]  | XOFF[1] | XOFF[0] | Per chip     | w       |
| 0x22 | XOFFH | X-Offset<br>MSB Register | XGAIN[8] | Resv    | XOFF[13] | XOFF[12] | XOFF[11] | XOFF[10] | XOFF[9] | XOFF[8] | Per chip     | W       |

#### 11.15 Y-AXIS OFFSET REGISTERS

This register contains a signed 2's complement 14-bit value applied as an offset adjustment to the output of the sensor values, prior to being sent to the OUT registers. The Power-On-Reset value for each chip is unique and is set as part of factory calibration. If necessary, this value can be overwritten by software.

| Addr | Name  | Description              | Bit 7    | Bit 6   | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1   | Bit 0   | POR<br>Value | R/<br>W |
|------|-------|--------------------------|----------|---------|----------|----------|----------|----------|---------|---------|--------------|---------|
| 0x23 | YOFFL | Y-Offset<br>LSB Register | YOFF[7]  | YOFF[6] | YOFF[5]  | YOFF[4]  | YOFF[3]  | YOFF[2]  | YOFF[1] | YOFF[0] | Per chip     | w       |
| 0x24 | YOFFH | Y-Offset<br>MSB Register | YGAIN[8] | Resv    | YOFF[13] | YOFF[12] | YOFF[11] | YOFF[10] | YOFF[9] | YOFF[8] | Per chip     | w       |

#### 11.16 Z-AXIS OFFSET REGISTERS

This register contains a signed 2's complement 14-bit value applied as an offset adjustment to the output of the sensor values, prior to being sent to the OUT registers. The Power-On-Reset value for each chip is unique and is set as part of factory calibration. If necessary, this value can be overwritten by software.

| Addr | Name  | Description              | Bit 7    | Bit 6   | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1   | Bit 0   | POR<br>Value | R/<br>W |
|------|-------|--------------------------|----------|---------|----------|----------|----------|----------|---------|---------|--------------|---------|
| 0x25 | ZOFFL | Z-Offset<br>LSB Register | ZOFF[7]  | ZOFF[6] | ZOFF[5]  | ZOFF[4]  | ZOFF[3]  | ZOFF[2]  | ZOFF[1] | ZOFF[0] | Per chip     | w       |
| 0x26 | ZOFFH | Z-Offset<br>MSB Register | ZGAIN[8] | Resv    | ZOFF[13] | ZOFF[12] | ZOFF[11] | ZOFF[10] | ZOFF[9] | ZOFF[8] | Per chip     | w       |

## 11.17 X-AXIS GAIN REGISTERS

The gain value is an unsigned 9-bit number.

| Addr | Name  | Description              | Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    | POR<br>Value | R/<br>W |
|------|-------|--------------------------|----------|----------|----------|----------|----------|----------|----------|----------|--------------|---------|
| 0x22 | XOFFH | X-Offset<br>MSB Register | XGAIN[8] | Resv     | XOFF[13] | XOFF[12] | XOFF[11] | XOFF[10] | XOFF[9]  | XOFF[8]  | Per chip     | w       |
| 0x27 | XGAIN | X Gain Register          | XGAIN[7] | XGAIN[6] | XGAIN[5] | XGAIN[4] | XGAIN[3] | XGAIN[2] | XGAIN[1] | XGAIN[0] | Per chip     | W       |

## 11.18 Y-AXIS GAIN REGISTERS

The gain value is an unsigned 9-bit number.

| Addr | Name  | Description              | Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    | POR<br>Value | R/<br>W |
|------|-------|--------------------------|----------|----------|----------|----------|----------|----------|----------|----------|--------------|---------|
| 0x24 | YOFFH | Y-Offset<br>MSB Register | YGAIN[8] | Resv     | YOFF[13] | YOFF[12] | YOFF[11] | YOFF[10] | YOFF[9]  | YOFF[8]  | Per chip     | w       |
| 0x28 | YGAIN | Y Gain Register          | YGAIN[7] | YGAIN[6] | YGAIN[5] | YGAIN[4] | YGAIN[3] | YGAIN[2] | YGAIN[1] | YGAIN[0] | Per chip     | w       |

## 11.19 Z-AXIS GAIN REGISTERS

The gain value is an unsigned 9-bit number.

| Addr | Name  | Description              | Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    | POR<br>Value | R/<br>W |
|------|-------|--------------------------|----------|----------|----------|----------|----------|----------|----------|----------|--------------|---------|
| 0x26 | ZOFFH | Z-Offset<br>MSB Register | ZGAIN[8] | Resv     | ZOFF[13] | ZOFF[12] | ZOFF[11] | ZOFF[10] | ZOFF[9]  | ZOFF[8]  | Per chip     | w       |
| 0x29 | ZGAIN | Z Gain Register          | ZGAIN[7] | ZGAIN[6] | ZGAIN[5] | ZGAIN[4] | ZGAIN[3] | ZGAIN[2] | ZGAIN[1] | ZGAIN[0] | Per chip     | w       |

## 11.20 SHAKE\_TH: SHAKE THRESHOLD REGISTER

SHAKE\_TH has a baseline value of 1.3g plus a threshold, SHAKE\_TH. The shake threshold can range from 0.925g to 1.672g. The value is an 8-bit signed 2's complement number. The resolution is approximately 2.9mg/bit. See also Section 9.5 Shake Detection.

Shake Event = 
$$( mag(X) > 1.3g + SHAKE\_TH )$$
 or  $( mag(Y) > 1.3g + SHAKE\_TH )$  or  $( mag(Z) > 1.3g + SHAKE\_TH )$ 

| Addr | Name     | Description                 | Bit 7 | Bit 6 | Bit 5 | Bit 4      | Bit 3      | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|----------|-----------------------------|-------|-------|-------|------------|------------|-------|-------|-------|--------------|---------|
| 0x2B | SHAKE_TH | Shake Threshold<br>Register |       |       | Sign  | ed 2's com | nplement v | alue  |       |       | 0x00         | w       |

| SHAKE_TH[7:0] | Description (~2.9mg/LSB)  |
|---------------|---------------------------|
| 0x80          | Shake threshold is 0.925g |
| 0x00          | Shake threshold is 1.3g   |
| 0x7F          | Shake threshold is 1.672g |

Table 40. SHAKE\_TH Threshold Register Settings

## 11.21 UD\_Z\_TH: UP/DOWN Z AXIS THRESHOLD REGISTER

The threshold value, UD\_Z\_TH[7:0] is an 8-bit signed 2's complement number that can range from 0.425g to 1.172g, for determination of the POLA orientation bits. The resolution is approximately 2.9mg/bit. See also Section <u>9.3 Portrait/Landscape</u>.

| 4 | Addr | Name    | Description    | Bit 7 | Bit 6 | Bit 5 | Bit 4      | Bit 3      | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|---|------|---------|----------------|-------|-------|-------|------------|------------|-------|-------|-------|--------------|---------|
|   |      |         | Up/Down Z Axis |       |       |       |            |            |       |       |       |              |         |
| ( | 0x2C | UD_Z_TH | Threshold      |       |       | Sign  | ed 2's com | iplement v | alue  |       |       | 0x00         | W       |
|   |      |         | Register       |       |       |       |            |            |       |       |       |              |         |

| UD_Z_TH[7:0] | Description (~2.9mg/LSB)           |
|--------------|------------------------------------|
| 0x80         | Up/down Z axis threshold is 0.425g |
| 0x00         | Up/down Z axis threshold is 0.8g   |
| 0x7F         | Up/down Z axis threshold is 1.172g |

Table 41. Up/Down Z-axis Threshold Register Settings

## 11.22 UD\_X\_TH: UP/DOWN X AXIS THRESHOLD REGISTER

This 8-bit unsigned value is an offset that is added to the magnitude of the X-axis accelerometer measurement. The range of the offset is 0g to 0.747g; the resolution is approximately 2.9mg/bit. See also Section <u>9.3 Portrait/Landscape</u>.

Increasing this value in conjunction with the <u>RL\_Y\_TH: Right/Left Y Axis Threshold Register</u> widens the deadband in portrait /landscape detection.

For most applications, the same value should be written to both registers.

| Addr | Name    | Description    | Bit 7          | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|---------|----------------|----------------|-------|-------|-------|-------|-------|-------|-------|--------------|---------|
|      |         | Up/Down X Axis |                |       |       |       |       |       |       |       |              |         |
| 0x2D | UD_X_TH | Threshold      | Unsigned value |       |       |       |       |       |       |       | 0x00         | W       |
|      |         | Register       |                |       |       |       |       |       |       |       |              |         |

| UD_X_TH[7:0] | Description (~2.9mg/LSB)              |
|--------------|---------------------------------------|
| 0x00         | Up/down X threshold offset is 0g      |
| 0xFF         | Up/down X threshold offset is +0.747g |

Table 42. Up/Down X-axis Threshold Register Settings

## 11.23 RL\_Z\_TH: RIGHT/LEFT Z AXIS THRESHOLD REGISTER

The threshold value, RL\_Z\_TH[7:0] is an 8-bit signed 2's complement number that can range from 0.425g to 1.172g, for determination of the POLA orientation bits. The resolution is approximately 2.9mg/bit. See also Section <u>9.3 Portrait/Landscape</u>.

| Addr | Name              | Description | Bit 7 | Bit 6                       | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|-------------------|-------------|-------|-----------------------------|-------|-------|-------|-------|-------|-------|--------------|---------|
|      | Right/Left Z Axis |             |       |                             |       |       |       |       |       |       |              |         |
| 0x2E | RL_Z_TH           | Threshold   |       | Signed 2's complement value |       |       |       |       |       |       | 0x00         | W       |
|      |                   | Register    |       |                             |       |       |       |       |       |       |              |         |

| RL_Z_TH[7:0] | Description (~2.9mg/LSB)              |
|--------------|---------------------------------------|
| 0x80         | Right/left Z axis threshold is 0.425g |
| 0x00         | Right/left Z axis threshold is 0.8g   |
| 0x7F         | Right/left Z axis threshold is 1.172g |

Table 43. Right/Left Z-axis Threshold Register Settings

## 11.24 RL\_Y\_TH: RIGHT/LEFT Y AXIS THRESHOLD REGISTER

This 8-bit unsigned value is an offset this is added to the magnitude of the Y-axis accelerometer measurement. The range of the offset is 0g to 0.747g; the resolution is approximately 2.9mg/bit. See also Section <u>9.3 Portrait/Landscape</u>.

Increasing this value in conjunction with the <u>UD\_X\_TH: Up/Down X Axis Threshold Register</u> widens the dead-band in portrait /landscape detection.

For most applications, the same value should be written to both registers.

| Addr | Name    | Description       | Bit 7 | Bit 6          | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|---------|-------------------|-------|----------------|-------|-------|-------|-------|-------|-------|--------------|---------|
|      |         | Right/Left Y Axis |       |                |       |       |       |       |       |       |              |         |
| 0x2F | RL_Y_TH | Threshold         |       | Unsigned value |       |       |       |       |       |       | 0x00         | W       |
|      |         | Register          |       |                |       |       |       |       |       |       |              |         |

| RL_Y_TH[7:0] | Description (~2.9mg/LSB)                      |
|--------------|-----------------------------------------------|
| 0x00         | Right/left Y-axis threshold offset is 0g      |
| 0xFF         | Right/left Y-axis threshold offset is +0.747g |

Table 44. Right/Left Y-axis Threshold Register Settings

## 11.25 FB\_Z\_TH: FRONT/BACK Z AXIS THRESHOLD REGISTER

The threshold value, FB\_Z\_TH[7:0] is an 8-bit unsigned number that adds up to + 0.373g to the baseline detection level of 0.174g, in increments of approximately 1.46mg/LSB. Increasing the threshold value increases the hysteresis of the front/back detection level. See also Section 9.4 Front/Back.

| Addr | Name    | Description       | Bit 7          | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|---------|-------------------|----------------|-------|-------|-------|-------|-------|-------|-------|--------------|---------|
|      | FB_Z_TH | Front/Back Z Axis |                |       |       |       |       |       |       |       |              |         |
| 0x30 |         | Threshold         | Unsigned value |       |       |       |       |       |       |       | 0x00 V       | W       |
|      |         | Register          |                |       |       |       |       |       |       |       |              |         |

| FB_Z_TH[7:0] | Description (~1.46mg/LSB)        |
|--------------|----------------------------------|
| 0x00         | Front/back Z threshold is 0.174g |
| 0xFF         | Front/back Z threshold is 0.547g |

Table 45. Front/Back Z-axis Threshold Register Settings

## 11.26 DROP\_TH: DROP THRESHOLD REGISTER

The threshold value, DROP\_TH[7:0] is an 8-bit signed 2's complement number that adjusts the drop-detection baseline detection level of 0.5g. See also Section <u>9.6 Drop Detection</u>.

| Addr | Name    | Description                | Bit 7 | Bit 6                       | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|---------|----------------------------|-------|-----------------------------|-------|-------|-------|-------|-------|-------|--------------|---------|
| 0x31 | DROP_TH | Drop Threshold<br>Register |       | Signed 2's complement value |       |       |       |       |       |       |              | w       |

| DROP_TH[7:0] | Description (~2.9mg/LSB) |
|--------------|--------------------------|
| 0x80         | Drop threshold is 0.125g |
| 0x00         | Drop threshold is 0.5g   |
| 0x7F         | Drop threshold is 0.872g |

**Table 46. Drop Threshold Register Settings** 

## 11.27 TAP\_TH: TAP THRESHOLD REGISTER

The threshold value, TAP\_TH[7:0] is an 8-bit unsigned number that species the threshold detection level for all tap events. This value is not an offset, but a magnitude which determines the minimum level for a valid tap event. The detector is implemented as a 2<sup>nd</sup>-order high pass filter. As such, the units are the 2<sup>nd</sup> derivative of acceleration, also known as 'snap'. The full range is 0 to 12 snap. The resolution is ~47 milliSnap/bit. See also Section <u>9.7 Tap Detection</u>.

| Addr | Name   | Description               | Bit 7 | Bit 6          | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|--------|---------------------------|-------|----------------|-------|-------|-------|-------|-------|-------|--------------|---------|
| 0x32 | TAP_TH | Tap Threshold<br>Register |       | Unsigned value |       |       |       |       |       |       |              | w       |

| TAP_TH[7:0] | Description (~47 mSnap/LSB) |  |  |  |
|-------------|-----------------------------|--|--|--|
| 0x00        | Tap threshold is 0 snap     |  |  |  |
| 0x80        | Tap threshold is 6 snap     |  |  |  |
| 0xFF        | Tap threshold is 12 snap    |  |  |  |

Table 47. TAP\_TH Tap Threshold Register Settings

## 11.28 PCODE: PRODUCT CODE

This register returns a value specific to the part number of this mCube device, noted below.

| Addr | Name  | Description              | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W |
|------|-------|--------------------------|-------|-------|-------|-------|-------|-------|-------|-------|--------------|---------|
| 0x3B | PCODE | Product Code<br>Register |       |       |       | 0x    | 39    |       |       |       | 0x39         | R       |

## 12 EXAMPLE MC3430 CONFIGURATION

This section shows some example configurations, for demonstration purposes. The sequences are described as register read and write cycles; the I2C device ID and protocol are implied.

#### 12.1 EXAMPLE: TAP DEMO

| Sequence | Register | Data to Write | Comments                                                                                            |
|----------|----------|---------------|-----------------------------------------------------------------------------------------------------|
| 1        | 0x07     | 0x43          | Go to STANDBY state, configure INTN pin, active low (IAH = 0), active drive (IPP = 1)               |
| 2        | 0x05     | 0x00          | Sleep Counter is 0                                                                                  |
| 3        | 0x08     | 0x00          | Sample rate is continuous, 128 samples/sec                                                          |
| 4        | 0x09     | 0x80          | Enable Tap detection on Z-axis                                                                      |
| 5        | 0x0B     | 0x00          | Set drop mode A, no debounce, no drop interrupt                                                     |
| 6        | 0x31     | 0x80          | Set a very low drop threshold (to avoid frequent drop detection)                                    |
| 7        | 0x0A     | 0x03          | Tap detected for pulses > Tap threshold and for 4 or fewer sample periods                           |
| 8        | 0x32     | 0x5C          | Tap threshold set to ~4.3 snap                                                                      |
| 9        | 0x06     | 0x04          | Enable Tap interrupt, disable others                                                                |
| 10       | 0x07     | 0x41          | Go to WAKE state, enable sampling, configure INTN pin, active low (IAH = 0), active drive (IPP = 1) |

Table 48. Tap Demo Register Sequence

#### To observe the demo:

- Write the registers as shown above.
- Tap the device in the Z-direction
- Observe the interrupt trigger
- Read <u>TILT: Status Register</u> to reset the Tap interrupt
- Tap the device in the X and Y directions
- Observer no interrupt triggers

# 12.2 EXAMPLE: GINT INTERRUPT WITH AUTO-WAKE AND AUTO-SNIFF ENABLED

| Sequence | Register | Data to<br>Write | Comments                                                                                                                                                                  |
|----------|----------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1        | 0x07     | 0x43             | Go to STANDBY state Disable auto-wake / auto-sniff Configure INTN pin, active low (IAH = 0), active drive (IPP = 1) Set Sleep Counter prescaler to divide by 1 (SCPS = 0) |
| 2        | 0x08     | 0x12             | Set: Sniff state sample rate to 8 samples/second Wake state sample rate to 32 samples/second                                                                              |
| 3        | 0x06     | 0x11             | Enable GINT and FBINT interrupt bits (continuous sample interrupt and FRONT/BACK interrupt)                                                                               |
| 4        | 0x05     | 0xFF             | Set the SC sleep counter timeout: Set to 8 seconds, because SCPS = 0 and SC = 0xFF, which is the maximum, from Table 31.                                                  |
| 5        | 0x07     | 0x41             | Go to Wake state                                                                                                                                                          |
| 6        | 0x07     | 0x58             | Allow state to change via auto-wake/sniff (AWE = 1, ASE = 1) and maintain other settings                                                                                  |

Table 49. GINT Interrupt Register Sequence

#### To run the demo:

- Read X, Y, Z registers (0x00, 0x01, 0x02) on every INT pin assertion. A fast ISR (interrupt service routine) is recommended, faster than 32 reads / second.
- Lay the board flat on a surface. Observe the switch to slower sample rate (8Hz) after approximately 8 seconds of inactivity by observing the INT signal on an oscilloscope.
- Flip the device over (z axis) and observe an immediate exit from sniff state to wake state. This
  may be observed by viewing GINT on scope or reading the <u>OPSTAT</u>: <u>Operational State Status</u>
  Register in real time.

# 13 INDEX OF TABLES

| Table 1. Order Information                                                              | 5  |
|-----------------------------------------------------------------------------------------|----|
| Table 2. Pin Description                                                                | 8  |
| Table 3. Absolute Maximum Ratings                                                       | 12 |
| Table 4. Sensor Characteristics                                                         | 13 |
| Table 5. Electrical Characteristics                                                     | 14 |
| Table 6. I2C Electrical and Timing Characteristics                                      | 15 |
| Table 7. I2C Timing Characteristics                                                     | 16 |
| Table 8. Summary of Resolution, Range, and Scaling                                      | 17 |
| Table 9. Operational States                                                             | 19 |
| Table 10. Forcing Operational States                                                    | 21 |
| Table 11. Auto-Wake / Sniff Operational State Flow Truth Table                          | 21 |
| Table 12. WAKE State Sample Rates                                                       | 22 |
| Table 13. SNIFF State Sample Rates                                                      | 22 |
| Table 14. Interrupt Support                                                             | 24 |
| Table 15. Detection Logic Event Evaluation                                              | 26 |
| Table 16. Portrait/Landscape Event Evaluation Criteria                                  | 29 |
| Table 17. Some Approximate X and Y-axis Portrait/Landscape Evaluation Angles and Values | 30 |
| Table 18. Some Approximate Z-axis Portrait/Landscape Evaluation Angles and Values       | 30 |
| Table 19. Portrait/Landscape TILT: Status Register Assignments                          | 31 |
| Table 20. BAFR Bit Assignments in the TILT: Status Register                             | 33 |
| Table 21. Front/Back Event Evaluation                                                   | 33 |
| Table 22. Approximate Front/Back Evaluation Angles and Values                           | 33 |
| Table 23. SHAKE Event Evaluation (Baseline + Offset)                                    | 34 |
| Table 24. Drop Event Evaluation                                                         | 36 |
| Table 25. Default Tap Event Evaluation                                                  | 38 |
| Table 26. Register Summary                                                              | 44 |
| Table 27. Accelerometer Value Registers                                                 | 45 |
| Table 28. TILT Status Register Settings                                                 | 46 |
| Table 29. Operational State Status Register                                             | 48 |
| Table 30. Sleep Counter Register Settings                                               | 49 |
| Table 31. Sleep Counter Timeout Settings                                                | 49 |

## MC3430 3-Axis Accelerometer

| Table 32. Interrupt Enable Register Settings            | 50 |
|---------------------------------------------------------|----|
| Table 33. Mode Register Functionality                   | 51 |
| Table 34. Wake/Sniff Sample Rate Settings               | 52 |
| Table 35. Tilt Debounce Filter Settings                 | 53 |
| Table 36. TAPEN Register Settings                       | 54 |
| Table 37. TAPP Tap Pulse Register Settings              | 55 |
| Table 38. Drop Event Control Register Settings          | 56 |
| Table 39. SH_DB Shake Debounce Register Settings        | 57 |
| Table 40. SHAKE_TH Threshold Register Settings          | 65 |
| Table 41. Up/Down Z-axis Threshold Register Settings    | 66 |
| Table 42. Up/Down X-axis Threshold Register Settings    | 67 |
| Table 43. Right/Left Z-axis Threshold Register Settings | 68 |
| Table 44. Right/Left Y-axis Threshold Register Settings | 69 |
| Table 45. Front/Back Z-axis Threshold Register Settings | 70 |
| Table 46. Drop Threshold Register Settings              | 71 |
| Table 47. TAP_TH Tap Threshold Register Settings        | 72 |
| Table 48. Tap Demo Register Sequence                    | 74 |
| Table 49 GINT Interrunt Register Sequence               | 75 |

# 14 REVISION HISTORY

| Date    | Revision         | Description                                                                                                                       |
|---------|------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 2012-03 | APS-048-0011v1.0 | First release.                                                                                                                    |
| 2012-10 | APS-048-0011v1.1 | Changed device orientation pictures. Change PCODE. Updated current specs. Clarified text in tables, gain registers and footnotes. |
| 2013-03 | APS-048-0011v1.2 | Add Tape and Reel info.                                                                                                           |
| 2013-08 | APS-048-0011v1.3 | Added pin numbers to schematic view.                                                                                              |
| 2014-09 | APS-048-0011v1.4 | Removed I5 from order information.                                                                                                |
| 2014-10 | APS-048-0011v1.5 | Updated noise specification. Added pull-up resistors explicitly to typical application circuit. Cleaned up some whitespace.       |

## 15 LEGAL

- 1. M-CUBE reserves the right to make corrections, modifications, enhancements, improvements and other changes to its products and to this document at any time and discontinue any product without notice. The information contained in this document has been carefully checked and is believed to be accurate. However, M-CUBE shall assume no responsibilities for inaccuracies and make no commitment to update or to keep current the information contained in this document.
- 2. M-CUBE products are designed only for commercial and normal industrial applications and are not suitable for other purposes, such as: medical life support equipment; nuclear facilities; critical care equipment; military / aerospace; automotive; security or any other applications, the failure of which could lead to death, personal injury or environmental or property damage. Use of the products in unsuitable applications are at the customer's own risk and expense.
- 3. M-CUBE shall assume no liability for incidental, consequential or special damages or injury that may result from misapplication or improper use of operation of the product.
- 4. No license, express or implied, by estoppel or otherwise, to any intellectual property rights of M-CUBE or any third party is granted under this document.
- 5. M-CUBE makes no warranty or representation of non-infringement of intellectual property rights of any third party with respect to the products. M-CUBE specifically excludes any liability to the customers or any third party regarding infringement of any intellectual property rights, including the patent, copyright, trademark or trade secret rights of any third party, relating to any combination, machine, or process in which the M-CUBE products are used.
- 6. Examples of use described herein are provided solely to guide use of M-CUBE products and merely indicate targeted characteristics, performance and applications of products. M-CUBE shall assume no responsibility for any intellectual property claims or other problems that may result from applications based on the examples described herein
- 7. Information described in this document including parameters, application circuits and its constants and calculation formulas, programs and control procedures are provided for the purpose of explaining typical operation and usage. "Typical" parameters that may be provided in M-CUBE data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters including "Typicals," must be validated for each customer application by customer's technical experts. In no event shall the information described be regarded as a guarantee of conditions or characteristics of the products. Therefore, the customer should evaluate the design sufficiently as whole system under the consideration of various external or environmental conditions and determine their application at the customer's own risk. M-CUBE shall assume no responsibility or liability for claims, damages, costs and expenses caused by the customer or any third party, owing to the use of the above information.



is a trademark of M-CUBE, Inc.

M-CUBE and the M-CUBE logo are trademarks of M-CUBE, Inc.,

All other product or service names are the property of their respective owners.

© M-CUBE, Inc. 2014. All rights reserved.