#### GENERAL DESCRIPTION The MC3416-P is a small form factor, 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. The MC3416-P features a dedicated motion block which implements algorithms to support "any motion" and shake detection, tilt/flip and tilt 35 position detection. Low power consumption and small size are inherent in the monolithic fabrication approach, where the MEMS accelerometer is integrated in a single-chip with the electronics integrated circuit. In the MC3416-P the internal sample rate can be set from 128 to 1024 samples / second. The device supports the reading of sample and event status via polling or interrupts. #### **FEATURES** ### Range, Sampling & Power - ±2, ±4, ±8, ±12, ±16g range - 16-bit resolution - 128 to 1024 Output Data Rate - 4 µA typical Standby current - Low typical active current ### Simple System Integration - I2C interface, up to 1 MHz - 2x2x0.92 mm 12-pin LGA package - High reliability thru single-chip 3D silicon MEMS technology - RoHS compliant ### **Applications** - Wearable - IoT & IoMT - Remote controls, gaming - Vibration in Cell phone - VR & game controllers Information furnished by MEMSIC is believed to be accurate and reliable. However, no responsibility is assumed by MEMSIC for its use, or for any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of MEMSIC. © MEMSIC Semiconductor (Tianjin) Co., Ltd. www.memsic.com # TABLE OF CONTENTS | 1 | Orc | ler Information | 4 | |------|------|-----------------------------------------------|------| | 2 | Fur | nctional Block Diagram | 5 | | 3 | Pad | ckaging and Pin Description | 6 | | 3.1 | | Package Outline | 6 | | 3.2 | | Package Orientation | 7 | | 3.3 | | Pin Description | 8 | | 3.4 | | Typical Application Circuits | 9 | | 3.5 | | Tape and Reel | . 12 | | 3.6 | | Soldering Profile | . 14 | | 3.7 | | Shipping and Handling Guidelines | . 14 | | 3.8 | | Moisture Sensitivity Level Control | . 14 | | 4 | Spe | ecifications | 15 | | 4.1 | | Absolute Maximum Ratings | . 15 | | 4.2 | | Sensor Characteristics | . 16 | | 4.3 | | Electrical and Timing Characteristics | . 17 | | 4. | .3.1 | Electrical Power and Internal Characteristics | . 17 | | 4. | 3.2 | I2C Electrical Characteristics | . 18 | | 4. | .3.3 | I2C Timing Characteristics | . 19 | | 5 | Gei | neral Operation | 20 | | 5.1 | | Sensor Sampling | 20 | | 5.2 | | Offset and Gain Calibration | 21 | | 5.3 | | Reset | 22 | | 6 | Ор | erational States | 23 | | 7 | Ор | erational State Flow | 24 | | 8 | Inte | errupts | 25 | | 8.1 | | Enabling and Clearing Interrupts | . 25 | | 8.2 | | ACQ_INT Interrupt | . 25 | | 9 | Sar | mpling | 26 | | 9.1 | | Continuous Sampling | . 26 | | 10 | I2C | Interface | 27 | | 10.1 | | Physical Interface | | | 10.2 | | Timing | | | | | · | | | 10.3 | 3 | I2C Message Format | 28 | |------|------|--------------------------------------------------|----| | 10.4 | 4 | Watchdog Timer | 28 | | 11 | Reg | gister Interface | 30 | | 11.1 | 1 | Register Summary | 30 | | 11.2 | 2 | Device Status Register | 32 | | 11.3 | 3 | Interrupt Enable Register | 33 | | 11.4 | 4 | Mode Register | 34 | | 11.5 | 5 | Sample Rate Register | 35 | | 11.6 | 3 | Motion Control Register | 36 | | 11.7 | 7 | XOUT, YOUT and ZOUT Data Accelerometer Registers | 37 | | 11.8 | 3 | Status Register | 38 | | 11.9 | 9 | Interrupt Status Register | 39 | | 11.1 | 10 | Range and Scale Control Register | 40 | | 11.1 | 11 | X-Axis Digital Offset Registers | 41 | | 11.1 | 12 | Y-Axis Digital Offset Registers | 42 | | 11.1 | 13 | Z-Axis Digital Offset Registers | 43 | | 11.1 | 14 | X-Axis Digital Gain Registers | 44 | | 11.1 | 15 | Y-Axis Digital Gain Registers | 45 | | 11.1 | 16 | Z-Axis Digital Gain Registers | 46 | | 11.1 | 17 | Tilt/Flip Threshold Registers | 47 | | 11.1 | 18 | Tilt/Flip Debounce Register | 48 | | 11.1 | 19 | AnyMotion Threshold Registers | 49 | | 11.2 | 20 | AnyMotion Debounce Register | 50 | | 11.2 | 21 | Shake Threshold Registers | 51 | | 11.2 | 22 | Shake Duration, Peak-to-Peak Registers | 52 | | 11.2 | 23 | Timer Control Register | 53 | | 12 | Inde | ex of Tables | 54 | | 13 | Rev | rision History | 56 | | | | | | # 1 ORDER INFORMATION **Table 1. Order Information** | Part Number | Resolution | Order Number | Package | Shipping | |-------------|------------|--------------|---------|-------------------| | MC3416-P | 16-bit | MC3416-P | VLGA-12 | Tape & Reel, 10Ku | **Table 2. Package Information** # **2 FUNCTIONAL BLOCK DIAGRAM** Figure 1. Block Diagram # **3 PACKAGING AND PIN DESCRIPTION** ### 3.1 PACKAGE OUTLINE | | DIM | ENSION (I | MM) | | | |--------|------------|-----------|-------|--|--| | SYMBOL | MIN. | MIN. NOM. | | | | | Α | 0.85 | 0.92 | 1.00 | | | | D | | 2.00 BS | C | | | | 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 ### 3.2 PACKAGE ORIENTATION Figure 3. Package Orientation Figure 4. Package Axis Reference #### 3.3 PIN DESCRIPTION | Pin | Name | Function | |-----|-------------------|-----------------------------------| | 1 | VPP | Connect to GND | | 2 | SDA <sup>1</sup> | I2C serial data input/output | | 3 | VDD/VDDIO | Power supply | | 4 | NC | No connect | | 5 | INTN <sup>2</sup> | Interrupt active LOW <sup>3</sup> | | 6 | NC | No Connect | | 7 | NC | No Connect | | 8 | NC | No Connect | | 9 | GND | Ground | | 10 | NC | No Connect | | 11 | NC | No connect | | 12 | SCL <sup>1</sup> | I2C serial clock input | **Table 3. Pin Description** ### Notes: - 1) This pin requires a pull-up resistor, typically $4.7k\Omega$ to pin VDD/VDDIO. 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 VDD/VDDIO. - 3) INTN pin polarity is programmable in the mode register. #### 3.4 TYPICAL APPLICATION CIRCUITS NOTE<sup>1</sup>: Rp are typically $4.7k\Omega$ pullup resistors to VDD/VDDIO, per I2C specification. When pin VDD/VDDIO 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 5. Typical Application Circuit for 3DOF Solution 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 VDD/VDDIO pin. NOTE<sup>1</sup>: Rp are typically 4.7kΩ pullup resistors to VDD/VDDIO, per I2C specification. When pin VDD/VDDIO 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. NOTE<sup>3</sup>: **Bold pin names** are from MC6470 and MC7030. Connection to VDDM is required, INTM and A5 are optional. Figure 6. Typical Application Circuit for 3DOF, 6DOF, 9DOF Pin Compatibility (MC6470 and MC7030) 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 VDD/VDDIO pin. NOTE<sup>1</sup>: Rp are typically 4.7kΩ pullup resistors to VDD/VDDIO, per I2C specification. When pin VDD/VDDIO is powered down, SDA and SCL will be driven low by internal ESD diodes. NOTE<sup>2</sup>: VPP must be floated to be compatible with MC3413. NOTE<sup>3</sup>: **Bold pin names** are from MC3413. NOTE<sup>4</sup>: Attach typical 4.7kΩ pullup resistor if INTN is defined as open-drain. Figure 7. Typical Application Circuit for 3DOF, 6DOF, 9DOF Pin Compatibility (MC3413) 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 VDD/VDDIO pin. ### 3.5 TAPE AND REEL Devices are shipped in reels, in standard cardboard box packaging. See <u>Figure 8. MC3416-P</u> <u>Tape Dimensions</u> and <u>Figure 9. MC3416-P Reel Dimensions</u>. - 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 8. MC3416-P Tape Dimensions • Dimensions in mm. Figure 9. MC3416-P Reel Dimensions #### 3.6 SOLDERING PROFILE The LGA package follows the reflow soldering classification profiles described in *Joint Industry Standard, Moisture/Reflow Sensitivity Classification for Nonhermetic Surface Mount Devices*, document number J-STD-020E. Reflow soldering has a peak temperature (T<sub>P</sub>) of 260°C #### 3.7 SHIPPING AND HANDLING GUIDELINES Shipping and handling follow the standards described in *Joint Industry Standard, Handling, Packing, Shipping and Use of Moisture/Reflow Sensitive Surface Mount Devices*, document number J-STD-033C. The following are additional handling guidelines (refer to the MEMSIC document, PCB Design, Device Handling and Assembly Guidelines, for more information): - While the mechanical sensor is designed to handle high-g shock events, direct mechanical shock to the package should be avoided. - SMT assembly houses should use automated assembly equipment with either plastic nozzles or nozzles with compliant tips (for example, soft rubber or silicone). - Avoid g-forces beyond the specified limits during transportation. - Handling and mounting of sensors should be done in a defined and qualified installation. ### 3.8 MOISTURE SENSITIVITY LEVEL CONTROL The following are storage recommendations (refer to the MEMSIC document, PCB Design, Device Handling and Assembly Guidelines, for more information): - Store the tape and reel in the *unopened* dry pack, until required on the assembly floor. - If the dry pack has been opened or the reel has been removed from the dry pack, reseal the reel inside of the dry pack with a black protective belt. Avoid crushing the tape and reel. - Store the cardboard box in a vertical position. # **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 | Pin<br>VDD/VDDIO | -0.3 / +3.6 | V | | Acceleration, any axis, 100 μs | 9 мах | 10000 | g | | Ambient operating temperature | T <sub>OP</sub> | -40 / +85 | $^{0}C$ | | Storage temperature | T <sub>STG</sub> | -40 / +125 | $^{0}C$ | | ESD human body model | НВМ | ± 2000 | V | | Latch-up current at T <sub>op</sub> = 25 <sup>0</sup> C | I <sub>LU</sub> | 200 | mA | | Input voltage to non-power pin | Pins INTN, SCL and SDA | -0.3 / (VDD + 0.3) or 3.6<br>whichever is lower | V | **Table 4. Absolute Maximum Ratings** ### 4.2 SENSOR CHARACTERISTICS VDD = 2.8V, $T_{op}$ = 25 $^{0}$ C unless otherwise noted | Parameter | Conditions | Min | Тур | Max | Unit | | |-------------------------------------------------------|--------------------------------------------|----------|----------------------------------------|------|--------------------|--| | Acceleration range | | | ±2.0<br>±4.0<br>±8.0<br>±12.0<br>±16.0 | | g | | | | Acceleration range = ±2.0g | | 16384 | | | | | | Acceleration range = ±4.0g | | 8192 | | | | | Sensitivity | Acceleration range = ±8.0g | | 4096 | | LSB/g | | | | Acceleration range = ±12.0g | | 2730 | | | | | | Acceleration range = ±16.0g | | 2048 | | | | | Sensitivity Temperature Coefficient <sup>1</sup> | $-40 \le T_{op} \le +85 {}^{0}C$ | | ±0.025 | | %/ºC | | | Zero-g Offset | Chip Level<br>Board Level | | ±20<br>±50 | | mg | | | Zero-g Offset<br>Temperature Coefficient <sup>1</sup> | -40 ≤ T <sub>op</sub> ≤ +85 <sup>0</sup> C | | ±1 | | mg/ <sup>0</sup> C | | | RMS Noise | ODR = 1024 | | 1.2 (X,Y)<br>2.7 (Z) | | mg<br>RMS | | | Nonlinearity <sup>1</sup> | Acceleration range = ±2.0g | | 0.6 | | % FS | | | Cross-axis Sensitivity 1 | Between any two axes | | ±2 | | % | | | ODR, Output Data Rate | | 128 | | 1024 | Hz | | | <sup>1</sup> Values are based on device | characterization, not tested in proc | luction. | | | | | **Table 5. Sensor Characteristics** ### 4.3 ELECTRICAL AND TIMING CHARACTERISTICS ### 4.3.1 ELECTRICAL POWER AND INTERNAL CHARACTERISTICS | Parameter | Conditions | Symbol | Min | Тур | Max | Unit | |------------------------------------|---------------|--------|-----|-----|-----|------| | Supply voltage <sup>1</sup> | Pin VDD/VDDIO | VDD | 1.7 | | 3.6 | V | | Sample Rate Tolerance <sup>2</sup> | | Tclock | -2 | | 2 | % | <sup>&</sup>lt;sup>1</sup> Min and Max limits are hard limits without additional tolerance. Test condition: VDD = 2.8V, $T_{op} = 25$ $^{0}C$ unless otherwise noted | Parameter | Conditions | Min | Тур | Max | Unit | |--------------------|--------------|-----|-----------|-----|------| | Standby current | | | 4 | | μΑ | | WAKE state current | ODR = 128 Hz | | 73 | | μA | | Pad Leakage | Per I/O pad | -1 | 0.01 | 1 | μΑ | | Wake-Up time | | | 3 | | ms | | Start-Up time | | | 1/ODR+1mS | | ms | **Table 6. Electrical Characteristics** <sup>&</sup>lt;sup>2</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*VDD | V | | HIGH level input voltage | VIH | 0.7*VDD | - | V | | Hysteresis of Schmitt trigger inputs | Vhys | 0.05*VDD | - | V | | Output voltage, pin INTN, lol ≤ 2 mA | Vol | 0 | 0.4 | V | | Output voltage, pili livity, loi = 2 miA | Voh | 0 | 0.9*VDD | V | | Output voltage, pin SDA (open drain),<br>lol ≤ 1 mA | Vols | - | 0.1*VDD | V | | Input current, pins SDA and SCL (input voltage between 0.1*VDD and 0.9*VDD max) | li | -10 | 10 | μΑ | | Capacitance, pins SDA and SCL <sup>1</sup> | Ci | - | 10 | pF | <sup>&</sup>lt;sup>1</sup> Values are based on device characterization, not tested in production. **Table 7. I2C Electrical and Timing Characteristics** #### NOTES: - If multiple slaves are connected to the I2C signals in addition to this device, only 1 pullup resistor on each of SDA and SCL should exist. Also, care must be taken to not violate the I2C specification for capacitive loading. - When pin VDD/VDDIO is not powered and set to 0V, INTN, SDA and SCL will be held to VDD plus the forward voltage of the internal static protection diodes, typically about 0.6V. - When pin VDD/VDDIO 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. ### 4.3.3 I2C TIMING CHARACTERISTICS Figure 10. I2C Interface Timing | | | | Standard Mode Fast Mode Plus Fast Mode | | Fast Mode | | | | |----------------------|----------------------------------------------------------------------|--------|----------------------------------------|-----|-----------|------|------|-------| | Parameter | Description | Min | Max | Min | Max | Min | Max | Units | | f <sub>SCL</sub> | SCL clock frequency | 0 | 100 | 0 | 400 | 0 | 1000 | kHz | | t <sub>HD;</sub> STA | Hold time (repeated) START condition | 4.0 | - | 0.6 | - | 0.26 | - | μs | | t <sub>LOW</sub> | LOW period of the SCL clock | 4.7 | - | 1.3 | - | 0.5 | - | μs | | t <sub>HIGH</sub> | HIGH period of the SCL clock | 4.0 | - | 0.6 | - | 0.26 | - | μs | | t <sub>SU;STA</sub> | Set-up time for a repeated START condition | 4.7 | - | 0.6 | - | 0.26 | - | μs | | t <sub>HD;DAT</sub> | Data hold time<br>for CBUS compatible masters<br>for I2C-bus devices | 5<br>0 | -<br>3.45 | - 0 | -<br>0.9 | - | - | μs | | t <sub>SU;DAT</sub> | Data set-up time | 250 | - | 100 | - | 50 | - | ns | | t <sub>su;sto</sub> | Set-up time for STOP condition | 4.0 | - | 0.6 | - | 0.26 | - | μs | | t <sub>BUF</sub> | Bus free time between a STOP and START | 4.7 | - | 1.3 | - | 0.5 | - | μs | **Table 8. 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 device supports the reading of samples and device status upon interrupt or by polling. ### 5.1 SENSOR SAMPLING In the WAKE state, acceleration data for X, Y, and Z axes is sampled at a rate between 31 and 998 samples/second. See the **Sample Rate Register** section. The detectable acceleration range is variable and is set in the RANGE bits of the <u>range and scale control register</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 | |------------|-----------------------|------------------------------|-----------------------------------|-----------------------------------|-------------------------------------| | 16-bit | ± 2g | ~.061 | 0x8000 | 0x7FFF | Signed 2's | | | ± 4g | ~.122 | (-32768) | (+32767) | complement number, results in | | | ± 8g | ~.244 | | | XOUT, YOUT, | | | ± 12g | ~.366 | | | ZOUT. The MSB is the sign bit. | | | ± 16g | ~.488 | | | (Integer interpretation also shown) | Table 9. 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. ### **5.3 RESET** The device can be completely reset via a software command. Writing register 0x1C with 0x40 (bit 6) executes the equivalent of a power-on reset. The POR sequence can take up to 1ms. It is recommended SW wait at least 2ms before attempting to access device after issuing this operation. The device must be placed in STANDBY mode before executing the reset. # **6 OPERATIONAL STATES** The device has two states of operation: STANDBY and WAKE. All states are controlled by the software, there is no automatic power control. The device defaults to the STANDBY state following a power-up and must be in the WAKE state before executing a reset. The time to change from the STANDBY to WAKE state takes one sample period (takes less than $10 \mu s$ ). | State | I2C<br>Bus | Description | |----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | STANDBY | R/W | <ul> <li>Lowest power consumption</li> <li>Internal clocking is halted</li> <li>No motion detection, sampling, or calibration</li> <li>The I2C bus can read and write to registers (resolution, range, thresholds and other settings can be changed)</li> <li>Reset not allowed</li> <li>Default state after a power-up</li> </ul> | | WAKE | R <sup>1</sup> | <ul> <li>Highest power consumption</li> <li>Internal clocking is enabled</li> <li>Continuous motion detection and sampling; automatic calibration is available</li> <li>The I2C bus can only write to the mode register¹ and read all other registers</li> <li>Reset allowed</li> </ul> | | 1 If the unloc | k bit in th | ne mode register is enabled, the I2C bus can write to all registers in the WAKE | **Table 10. Operational States** state. ### 7 OPERATIONAL STATE FLOW <u>Figure 11. Operational State Flow</u> shows the operational state flow for the device. The device defaults to STANDBY following power-on. Figure 11. Operational State Flow The operation state may be read from the STATE bits of the <u>device status register</u>. The operational state may be forced to a specific state by writing into the STATE bits of the <u>mode register</u>, as shown below. Two bits are specified in order to promote software compatibility with other MEMSIC devices. The operational state will stay in the mode specified until changed. | Action | Setting | Effect | |---------------------|-----------------|--------------------------------------------| | Force STANDBY State | STATE[1:0] = 00 | Switch to the STANDBY state and stay there | | Force STANDBT State | 31A1E[1.0] = 00 | Disable sensor and event sampling | | Force WAKE State | STATE[1:0] = 01 | Switch to WAKE state and stay there | | Force WARE State | 31A1E[1.0] = 01 | Continuous sampling | **Table 11. Forcing Operational States** ### 8 INTERRUPTS The sensor device utilizes output pin INT*n* to signal to an external microprocessor that an event has been detected. The microprocessor should contain an interrupt service routine which would perform certain tasks after receiving this interrupt and reading the associated status bits, perhaps after a sample was made ready. If interrupts are to be used, the microprocessor must 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. If polling is used, there is no need for the interrupt registers to be set up. For products that use polling, the microprocessor must periodically poll the sensor and read the status data (the INT*n* pin is not used). For most applications, this is likely best done at the sensor sampling rate or faster. **NOTE:** At least one I2C STOP condition must be present between samples in order for the sensor to update the sample data registers. #### 8.1 ENABLING AND CLEARING INTERRUPTS The <u>interrupt status register</u> contains the flag bits for the sample acquisition interrupt ACQ\_INT. The <u>interrupt enable register</u> determines if a flag event generates interrupts. The flags (and interrupts) are cleared and rearmed every time an interrupt status register is read. When an event is detected, it is masked with a flag bit in the interrupt enable register, and then the corresponding status bit is set in the status registers. The polarity and driving mode of the external interrupt signal may be chosen by setting the IPP and IAH bits in the **mode register**. #### 8.2 ACQ INT INTERRUPT The ACQ\_INT flag bit in the status registers is always active. This bit is cleared when it is read. When a sample has been produced, an interrupt will be generated only if the ACQ\_INT\_EN bit in the interrupt enable register is active. The frequency of the ACQ\_INT bit being set active is always the same as the sample rate. ### 9 SAMPLING ### 9.1 CONTINUOUS SAMPLING The device has the ability to read all sampled readings in a continuous sampling fashion. The device always updates the XOUT, YOUT, and ZOUT registers at the chosen ODR. An optional interrupt can be generated each time the sample registers have been updated (using the ACQ\_INT bit in the <u>interrupt enable register</u>). See the <u>ACQ\_INT Interrupt</u> section or <u>status register</u> for more information about ACQ\_INT. ### 10 I2C INTERFACE #### **10.1 PHYSICAL INTERFACE** The I2C slave interface operates at a maximum speed of 1 MHz. The SDA (data) is an open-drain, bi-directional pin and the SCL (clock) is an input pin. Note: 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 depends upon the state of the VPP pin during power-up as shown in the table below. After the I2C address is selected, it won't changed unless excuting one power on reset. An optional I2C watchdog timer can be enabled to prevent bus stall conditions. See the **Watchdog Timer** section for more information. | 7-bit Device ID | 8-bit Address – Write | 8-bit Address – Read | VPP level upon power-up | |---------------------|-----------------------|----------------------|-------------------------| | 0x4C<br>(0b1001100) | 0x98 | 0x99 | GND | | 0x6C<br>(0b1101100) | 0xD8 | 0xD9 | VDD | Table 12. I2C Address Selection The I2C interface remains active as long as power is applied to the VDD/VDDIO pin. In the 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 the WAKE state, only the <u>mode register</u> can be modified (see the <u>Operational States</u> section for more information). 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$ . #### **10.2 TIMING** See the **I2C Timing Characteristics** section for I2C timing requirements. #### 10.3 I2C MESSAGE FORMAT **Note:** At least one I2C STOP condition must be present between samples in order for the sensor to update the sample data registers. The device uses the following general format for writing to the internal registers: The I2C master generates a START condition and then supplies the 7-bit device ID. The $8^{th}$ bit is the R/W# flag (write cycle = 0). The device pulls SDA low during the $9^{th}$ clock cycle indicating a positive ACK. The second byte is the 8-bit register address of the device to access. The last byte is the data to write. Figure 12. I2C Message Format, Write Cycle, Single Register Write In a read cycle, the I2C master generates a START condition and then writes the device ID, R/W# flag (write cycle = 0), and register address. 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 13. 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. #### **10.4 WATCHDOG TIMER** The I2C watchdog timer, when enabled (see the <u>mode register</u>), prevents bus stall conditions when the master does not provide enough clocks to the slave to complete a read cycle. The I2C watchdog timer does not resolve why the master did not provide enough clocks to complete a read cycle, but it does prevent a slave from holding the bus indefinitely. During a read cycle, the slave that is actively driving the bus (SDA pin) does not release the bus until nine SCL clock edges are detected. While the SDA pin is held low by a slave opendrain output, any other I2C devices attached to the bus will not be able to communicate. If the slave does not see nine SCL clocks from the master within the timeout period (about 200 ms), the slave assumes a system problem has occurred and resets the I2C circuitry, releases the SDA pin, and readies the sensor for additional I2C commands. When an I2C watchdog timer event is triggered, the I2C\_WDT bit in the <u>device status</u> <u>register</u> is activated by the Watchdog timer hardware. No other registers are changed. External software can detect this activation by reading the I2C\_WDT bit. Reading the interrupt status register (<u>0x14</u>) clears the I2C\_WDT bit. ### 11 REGISTER INTERFACE The device has a register interface which allows an 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. ### 11.1 REGISTER SUMMARY **NOTE:** Registers are not updated with new event status or samples while an I2C cycle is in process. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W <sup>1</sup> | |--------|-----------------|------------------------------------|-----------------------|-----------------------|-----------------|--------------------|------------------|-----------------|------------------|-----------------|--------------|------------------| | 0x00 - | - 0x04 | | | | | RESERVE | ED <sup>2</sup> | | | | | | | 0x05 | DEV_<br>STAT | <u>Device Status</u> | OTP_<br>BUSY | SEC_ENA<br>(TMODE) | Resv | I2C_WDT | Resv | RES_<br>MODE | STATE[1] | STATE[0] | 0x00 | R | | 0x06 | INTR_<br>CTRL | Interrupt Enable | ACQ_INT<br>_EN | AUTO_<br>CLR_EN | Resv | TILT_35_<br>INT_EN | SHAKE_<br>INT_EN | ANYM_<br>INT_EN | FLIP_INT_<br>EN | TILT_INT_<br>EN | 0x00 | W | | 0x07 | MODE | <u>Mode</u> | IAH | IPP | I2C_<br>WDT_POS | I2C_<br>WDT_NEG | Resv | 03 | STATE1 | STATE0 | 0x00 | W | | 0x08 | SR | Sample Rate | Resv | Resv | Resv | Resv | Resv | RATE[2] | RATE[1] | RATE[0] | 0x00 | W | | 0x09 | MOTION<br>_CTRL | Motion Control | MOTION<br>_RESET | RAW_<br>PROC_<br>STAT | Z_AXIS_<br>ORT | TILT_35_<br>EN | SHAKE_<br>EN | ANYM_EN | MOTION_<br>LATCH | TF_<br>ENABLE | 0x00 | W | | 0x0A | – 0x0C | | RESERVED <sup>2</sup> | | | | | | | | | | | 0x0D | XOUT_<br>EX_L | XOUT Accelerometer <u>Data LSB</u> | XOUT_<br>EX[7] | XOUT_<br>EX[6] | XOUT_<br>EX[5] | XOUT_<br>EX[4] | XOUT_<br>EX[3] | XOUT_<br>EX[2] | XOUT_<br>EX[1] | XOUT_<br>EX[0] | 0x00 | R | | 0x0E | XOUT_<br>EX_H | XOUT Accelerometer Data MSB | XOUT_<br>EX[15] | XOUT_<br>EX[14] | XOUT_<br>EX[13] | XOUT_<br>EX[12] | XOUT_<br>EX[11] | XOUT_<br>EX[10] | XOUT_<br>EX[9] | XOUT_<br>EX[8] | 0x00 | R | | 0x0F | YOUT_<br>EX_L | YOUT Accelerometer Data LSB | YOUT_<br>EX[7] | YOUT_<br>EX[6] | YOUT_<br>EX[5] | YOUT_<br>EX[4] | YOUT_<br>EX[3] | YOUT_<br>EX[2] | YOUT_<br>EX[1] | YOUT_<br>EX[0] | 0x00 | R | | 0x10 | YOUT_<br>EX_L | YOUT Accelerometer Data MSB | YOUT_<br>EX[15] | YOUT_<br>EX[14] | YOUT_<br>EX[13] | YOUT_<br>EX[12] | YOUT_<br>EX[11] | YOUT_<br>EX[10] | YOUT_<br>EX[9] | YOUT_<br>EX[8] | 0x00 | R | | 0x11 | ZOUT_<br>EX_L | ZOUT Accelerometer Data LSB | ZOUT_<br>EX[7] | ZOUT_<br>EX[6] | ZOUT_<br>EX[5] | ZOUT_<br>EX[4] | ZOUT_<br>EX[3] | ZOUT_<br>EX[2] | ZOUT_<br>EX[1] | ZOUT_<br>EX[0] | 0x00 | R | | 0x12 | ZOUT_<br>EX_H | ZOUT Accelerometer <u>Data MSB</u> | ZOUT_<br>EX[15] | ZOUT_<br>EX[14] | ZOUT_<br>EX[13] | ZOUT_<br>EX[12] | ZOUT_<br>EX[11] | ZOUT_<br>EX[10] | ZOUT_<br>EX[9] | ZOUT_<br>EX[8] | 0x00 | R | | 0x13 | STATUS<br>_2 | Status Register | NEW_<br>DATA | Resv | Resv | TILT_35_<br>FLAG | SHAKE_<br>FLAG | ANYM_<br>FLAG | FLIP_FLAG | TILT_<br>FLAG | 0x00 | R | | 0x14 | INTR_<br>STAT_2 | Interrupt Status<br>Register | ACQ_INT | Resv | Resv | TILT_35_<br>INT | SHAKE_<br>INT | ANYM_<br>INT | FLIP_INT | TILT_INT | 0x00 | R | | 0x15 - | - 0x1F | | | | | RESERVE | $ED^2$ | | | | | | | 0x18 | Chip ID | Chip Identification<br>Register | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0xA0 | R | | 0x20 | RANGE | Range Select Control | Resv | RANGE[2] | RANGE[1] | RANGE[0] | 14 | 03 | 03 | 14 | 0x00 | W | | 0x21 | XOFFL | X-Offset<br>LSB | 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 | XGAIN[8] | XOFF[14] | XOFF[13] | XOFF[12] | XOFF[11] | XOFF[10] | XOFF[9] | XOFF[8] | Per chip | W | | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W <sup>1</sup> | |------|-----------------------------------|----------------------------------------------------|-------------------------|--------------------|--------------------|--------------------|--------------------|--------------------|-------------------|-------------------|--------------|------------------| | 0x23 | YOFFL | <u>Y-Offset</u><br><u>LSB</u> | YOFF[7] | YOFF[6] | YOFF[5] | YOFF[4] | YOFF[3] | YOFF[2] | YOFF[1] | YOFF[0] | Per chip | W | | 0x24 | YOFFH | <u>Y-Offset</u><br><u>MSB</u> | YGAIN[8] | YOFF[14] | YOFF[13] | YOFF[12] | YOFF[11] | YOFF[10] | YOFF[9] | YOFF[8] | Per chip | W | | 0x25 | ZOFFL | Z-Offset<br>LSB | 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 | ZGAIN[8] | ZOFF[14] | ZOFF[13] | ZOFF[12] | ZOFF[11] | ZOFF[10] | ZOFF[9] | ZOFF[8] | Per chip | W | | 0x27 | XGAIN | X Gain | XGAIN[7] | XGAIN[6] | XGAIN[5] | XGAIN[4] | XGAIN[3] | XGAIN[2] | XGAIN[1] | XGAIN[0] | Per chip | W | | 0x28 | YGAIN | <u>Y Gain</u> | YGAIN[7] | YGAIN[6] | YGAIN[5] | YGAIN[4] | YGAIN[3] | YGAIN[2] | YGAIN[1] | YGAIN[0] | Per chip | W | | 0x29 | ZGAIN | Z Gain | ZGAIN[7] | ZGAIN[6] | ZGAIN[5] | ZGAIN[4] | ZGAIN[3] | ZGAIN[2] | ZGAIN[1] | ZGAIN[0] | Per chip | W | | 0x2A | -0x3F | | U | I. | I. | RESERVI | $ED^2$ | | I. | I. | | 1 | | 0x40 | TF_<br>THRESH<br>_LSB | Tilt/Flip Threshold<br>LSB | TF_<br>THR[7] | TF_THR[6] | TF_THR[5] | TF_THR[4] | TF_THR[3] | TF_THR[2] | TF_THR[1] | TF_<br>THR[0] | 0x00 | W | | 0x41 | TF_<br>THRESH<br>_MSB | Tilt/Flip Threshold<br>MSB | Resv | TF_<br>THR[14] | TF_<br>THR[13] | TF_<br>THR[12] | TF_<br>THR[11] | TF_<br>THR[10] | TF_THR[9] | TF_<br>THR[8] | 0x00 | W | | 0x42 | TF_DB | Tilt/Flip Debounce | TF_DB[7] | TF_DB[6] | TF_DB[5] | TF_DB[4] | TF_DB[3] | TF_DB[2] | TF_DB[1] | TF_DB[0] | 0x00 | W | | 0x43 | AM_<br>THRESH<br>_LSB | AnyMotion Threshold<br>LSB | ANYM_<br>THR[7] | ANYM_<br>THR[6] | ANYM_<br>THR[5] | ANYM_<br>THR[4] | ANYM_<br>THR[3] | ANYM_<br>THR[2] | ANYM_<br>THR[1] | ANYM_<br>THR[0] | 0x00 | w | | 0x44 | AM_<br>THRESH<br>_MSB | AnyMotion Threshold<br>MSB | Resv | ANYM_<br>THR[14] | ANYM_<br>THR[13] | ANYM_<br>THR[12] | ANYM_<br>THR[11] | ANYM_<br>THR[10] | ANYM_<br>THR[9] | ANYM_<br>THR[8] | 0x00 | w | | 0x45 | AM_DB | AnyMotion<br>Debounce | ANYM_<br>DB[7] | ANYM_<br>DB[6] | ANYM_<br>DB[5] | ANYM_<br>DB[4] | ANYM_<br>DB[3] | ANYM_<br>DB[2] | ANYM_<br>DB[1] | ANYM_<br>DB[0] | 0x00 | w | | 0x46 | SHK_<br>THRESH<br>_LSB | Shake Threshold LSB | SH_<br>THR[7] | SH_<br>THR[6] | SH_<br>THR[5] | SH_<br>THR[4] | SH_<br>THR[3] | SH_<br>THR[2] | SH_<br>THR[1] | SH_<br>THR[0] | 0x00 | w | | 0x47 | SHK_<br>THRESH<br>_MSB | Shake Threshold MSB | SH_<br>THR[15] | SH_<br>THR[14] | SH_<br>THR[13] | SH_<br>THR[12] | SH_<br>THR[11] | SH_<br>THR[10] | SH_<br>THR[9] | SH_<br>THR[8] | 0x00 | w | | 0x48 | PK_P2P_<br>DUR_<br>THRESH<br>_LSB | Peak-to-Peak Duration LSB | PK_P2P_<br>DUR[7] | PK_P2P_<br>DUR[6] | PK_P2P_<br>DUR[5] | PK_P2P_<br>DUR[4] | PK_P2P_<br>DUR[3] | PK_P2P_<br>DUR[2] | PK_P2P_<br>DUR[1] | PK_P2P_<br>DUR[0] | 0x00 | w | | 0x49 | PK_P2P_<br>DUR_<br>THRESH<br>_MSB | Shake Duration and<br>Peak-to-Peak<br>Duration MSB | Resv | SHK_CNT_<br>DUR[2] | SHK_CNT<br>_DUR[1] | SHK_CNT_<br>DUR[0] | PK_P2P_<br>DUR[11] | PK_P2P_<br>DUR[10] | PK_P2P_<br>DUR[9] | PK_P2P_<br>DUR[8] | 0x00 | W | | 0x4A | TIMER_<br>CTRL | <u>Timer Control</u> | TEMP_<br>PER_INT<br>_EN | | | TEMP_<br>PERIOD[0] | Resv | TILT_<br>35[2] | TILT_35[1] | TILT_<br>35[0] | 0x00 | W | $<sup>^{1}</sup>$ 'R' registers are read-only, via external I2C access. 'W' registers are read-write, via external I2C access. **Table 13. Register Summary** <sup>&</sup>lt;sup>2</sup> Registers designated as 'RESERVED' should not be accessed by software. <sup>&</sup>lt;sup>3</sup> Software must write a zero (0) to this bit. <sup>&</sup>lt;sup>4</sup> Software must write a one (1) to this bit. ### **11.2 DEVICE STATUS REGISTER** The device status register reports various conditions of the sensor circuitry. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|--------------|---------------|--------------|-------|-------|---------|-------|--------------|----------|----------|--------------|-----| | 0x05 | DEV_<br>STAT | Device Status | OTP_<br>BUSY | Resv | Resv | I2C_WDT | Resv | RES_<br>MODE | STATE[1] | STATE[0] | 0x00 | R | | Name | Description | |------------|-------------------------------------------------------------------------------------------------| | | Operating mode of the current device. | | | <b>00</b> : STANDBY. Clocks are not running and X, Y, and Z-axis data are not sampled. | | STATE[1:0] | <b>01</b> : WAKE. Clocks are running and X, Y, and Z-axis data are acquired at the sample rate. | | | 10: Reserved. | | | 11: Reserved. | | | Resolution mode of the current device. | | RES_MODE | <b>0</b> : 16-bit (high) resolution is enabled. | | | 1: Reserved. | | | I2C watchdog timeout. This bit is cleared when register 0x14 is read. | | I2C WDT | <b>0</b> : A watchdog event is not detected. | | 120_7401 | 1: A watchdog event has been detected by the hardware and the I2C slave | | | state machine is reset to idle. | | | One-Time programming (OTP) activity status. | | OTP_BUSY | <b>0</b> : Internal memory is idle and the device is ready to use. | | | 1: Internal memory is active and the device cannot be used. | **Table 14. Device Status Register** ### 11.3 INTERRUPT ENABLE REGISTER The interrupt enable register enables or disables the reporting of interrupt status for each interrupt source. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|---------------|------------------|----------------|-----------------|-------|--------------------|------------------|-----------------|-----------------|-----------------|--------------|-----| | 0x06 | INTR_<br>CTRL | Interrupt Enable | ACQ_INT_<br>EN | AUTO_<br>CLR_EN | Resv | TILT_35_<br>INT_EN | SHAKE_<br>INT_EN | ANYM_<br>INT_EN | FLIP_INT_<br>EN | TILT_INT_<br>EN | 0x00 | W | | Name | Description | |----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Use with the tilt/flip feature in the motion control register (register 0x09, bit 0) to | | TILT_INT_EN | activate the reporting status of the tilt interrupt. | | | 0: Tilt interrupt is disabled. | | | 1: Tilt interrupt is enabled. | | | Use with the tilt/flip feature in the motion control register (register 0x09, bit 0) to | | FLIP_INT_EN | activate the reporting status of the flip interrupt. | | | 0: Flip interrupt is disabled. | | | 1: Flip interrupt is enabled. | | | Use with the AnyMotion feature in the motion control register (register 0x09, bit | | ANYM_INT_EN | 2) to activate the reporting status of the AnyMotion interrupt. | | | O: AnyMotion interrupt is disabled. AnyMotion interrupt is analyted. | | | 1: AnyMotion interrupt is enabled. | | | Use with the shake feature in the motion control register (register 0x09, bit 3) and the AnyMotion feature in the motion control register (register 0x09, bit 2) to | | SHAKE_INT_EN | activate the reporting status of the shake interrupt. | | SHAKE_INT_EN | <b>0</b> : Shake interrupt is disabled. | | | 1: Shake interrupt is enabled. | | | Use with the tilt-35 feature in the motion control register (register 0x09, bit 4) | | | and the AnyMotion feature in the motion control register (register 0x09, bit 2) to | | TILT_35_INT_EN | activate the reporting status of the tilt-35 interrupt. | | | 0: Tilt-35 interrupt is disabled. | | | 1: Tilt-35 interrupt is enabled. | | | Clear pending interrupts automatically or by reading a register. Enabling more | | | than one interrupt timeout or service feature may produce unexpected results. | | AUTO_CLR_EN | <b>0</b> : Clear pending interrupts by reading register 0x14. | | | 1: Automatically clear pending interrupts if the interrupt condition is no longer | | | valid. Refer to Interrupts for more information about interrupts. | | | Generate interrupts. | | ACQ_INT_EN | <b>0</b> : Disable automatic interrupt after each sample (default). | | /\os_\\\\\\\ | 1: Enable automatic interrupt after each sample (activates the ACQ_INT flag, | | | bit 7, in register 0x14). | Table 15. Interrupt Enable Register ### 11.4 MODE REGISTER The mode register controls the active operating state of the accelerometer. This register can be written from all operational states (WAKE, or STANDBY). | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------------------------------------------|------|-------------|-------|-------|-----------------|-----------------|-------|-----------------------|----------|----------|--------------|-----| | 0x07 | MODE | Mode | IAH | IPP | I2C_<br>WDT_POS | I2C_<br>WDT_NEG | Resv | <b>0</b> <sup>1</sup> | STATE[1] | STATE[0] | 0x00 | W | | Software must write a zero (0) to bit 2. | | | | | | | | | | | | | | Name | Description | |-------------|------------------------------------------------------------------------------------------------------------------| | | Accelerometer operational state. <b>00</b> : STANDBY. Clocks are not running and X, Y, and Z-axis data are not | | STATE[1:0] | sampled. <b>01</b> : WAKE. Clocks are running and X, Y, and Z-axis data are acquired at the sample rate. | | | <ul><li>10: Reserved.</li><li>11: Reserved.</li></ul> | | | Watchdog timer for negative SCL stalls. | | I2C_WDT_NEG | <b>0</b> : The I2C watchdog timer for negative SCL stalls is disabled (default). | | | 1: The I2C watchdog timer for negative SCL stalls is enabled. | | | Watchdog timer for positive SCL stalls. | | I2C_WDT_POS | <b>0</b> : The I2C watchdog timer for positive SCL stalls is disabled (default). | | | 1: The I2C watchdog timer for positive SCL stalls is enabled. | | | Interrupt Push Pull. | | IPP | <b>0</b> : Interrupt pin INT <i>n</i> is open drain (default) and requires an external pull-up to pin VDD/VDDIO. | | | 1: Interrupt pin INT <i>n</i> is push-pull. No external pull-up resistor should be installed. | | | Interrupt Active High. | | IAH | <b>0</b> : Interrupt pin INT <i>n</i> is active low (default). | | | 1: Interrupt pin INT <i>n</i> is active high. | **Table 16. Mode Register States** ### 11.5 SAMPLE RATE REGISTER The sample rate register sets the sampling output data rate (ODR) for the sensor, the clock frequency of the main oscillator, and the oversampling ratio (OSR). | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|------|-------------|-------|-------|-------|-------|-------|---------|---------|---------|--------------|-----| | 0x08 | SR | Sample Rate | Resv | Resv | Resv | Resv | Resv | RATE[2] | RATE[1] | RATE[0] | 0x00 | W | | Name | Description | | | | | | | |-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | RATE[2:0] | Output data rate, determined by the frequency of the main oscillator and the OSR. 000: 128 (default, slowest) 001: 256 010: 512 011: Reserved. 100: Reserved. 101: 1024 (fastest) 110: Reserved. 111: Reserved. | | | | | | | **Table 17. Sample Rate Register** ### 11.6 MOTION CONTROL REGISTER The motion control register enables the flags and interrupts for motion detection features. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-----------------|----------------|------------------|-----------------------|----------------|----------------|--------------|---------|------------------|---------------|--------------|-----| | 0x09 | MOTION_<br>CTRL | Motion Control | MOTION_<br>RESET | RAW_<br>PROC_<br>STAT | Z_AXIS_<br>ORT | TILT_35_<br>EN | SHAKE_<br>EN | ANYM_EN | MOTION_<br>LATCH | TF_<br>ENABLE | 0x00 | W | | Name | Description | |-----------------|----------------------------------------------------------------------------------------| | | Enable or disable the tilt/flip feature. Used with the tilt/flip features in registers | | TF ENABLE | 0x13, 0x14, and 0x06. | | II _LINADLL | 0: Tilt/Flip feature is disabled (default). | | | 1: Tilt/Flip feature is enabled. | | | If motion interrupts are used, this bit is generally not used. | | MOTION_LATCH | Motion block does not latch outputs. | | | 1: Motion block latches outputs. | | | Enable or disable the AnyMotion feature. Used with the AnyMotion feature in | | | registers 0x13, 0x14, and 0x06 and the shake and tilt-35 features in registers | | ANYM_EN | 0x14 and 0x06. | | | AnyMotion feature is disabled (default). | | | 1: AnyMotion feature is enabled. | | | Enable or disable the shake feature. Used with the shake feature in registers | | SHAKE _EN | 0x13, 0x14, and 0x06. | | 0.1 | 0: Shake feature is disabled (default). | | | 1: Shake feature is enabled. ANYM_EN must also be enabled. | | | Enable or disable the tilt-35 feature. Used with tilt-35 feature in registers 0x13, | | TILT_35 _EN | 0x14, and 0x06. | | | 0: Tilt-35 feature is disabled (default). | | | 1: Tilt-35 feature is enabled. ANYM_EN must also be enabled. | | 7 AVIO ODT | Z-axis orientation. | | Z_AXIS_ORT | <b>0</b> : Z-axis orientation is positive through the top of the package (default). | | | 1: Z-axis orientation is positive through the bottom of the package. | | DAMA BROOK OTAT | Enable or disable filtering of motion data. | | RAW_PROC_STAT | <b>0</b> : Motion flag bits are filtered by debounce and other settings (default). | | | 1: Motion flag bits are real-time, raw data. | | | Motion block reset. This bit is not automatically cleared. | | MOTION_RESET | <b>0</b> : The motion block is not in reset (default). | | | 1: The motion block is held in reset. The software must set this bit for the | | | reset to be cleared. | **Table 18. Motion Control Register** # 11.7 XOUT, YOUT AND ZOUT DATA ACCELEROMETER REGISTERS X, Y, and Z-axis accelerometer measurements in 14-bit and 16-bit resolutions and are in a signed 2's complement format. In raw bypass mode (RBM), the 14-bit value is used. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|---------------|-----------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------------|----------------|--------------|-----| | 0x0D | XOUT_<br>EX_L | XOUT<br>Accelerometer<br>Data LSB | XOUT_<br>EX[7] | XOUT_<br>EX[6] | XOUT_<br>EX[5] | XOUT_<br>EX[4] | XOUT_<br>EX[3] | XOUT_<br>EX[2] | XOUT_<br>EX[1] | XOUT_<br>EX[0] | 0x00 | R | | 0x0E | XOUT_<br>EX_H | XOUT<br>Accelerometer<br>Data MSB | XOUT_<br>EX[15] | XOUT_<br>EX[14] | XOUT_<br>EX[13] | XOUT_<br>EX[12] | XOUT_<br>EX[11] | XOUT_<br>EX[10] | XOUT_<br>EX[9] | XOUT_<br>EX[8] | 0x00 | R | | 0x0F | YOUT_<br>EX_L | YOUT<br>Accelerometer<br>Data LSB | YOUT_<br>EX[7] | YOUT_<br>EX[6] | YOUT_<br>EX[5] | YOUT_<br>EX[4] | YOUT_<br>EX[3] | YOUT_<br>EX[2] | YOUT_<br>EX[1] | YOUT_<br>EX[0] | 0x00 | R | | 0x10 | YOUT_<br>EX_L | YOUT<br>Accelerometer<br>Data MSB | YOUT_<br>EX[15] | YOUT_<br>EX[14] | YOUT_<br>EX[13] | YOUT_<br>EX[12] | YOUT_<br>EX[11] | YOUT_<br>EX[10] | YOUT_<br>EX[9] | YOUT_<br>EX[8] | 0x00 | R | | 0x11 | ZOUT_<br>EX_L | ZOUT<br>Accelerometer<br>Data LSB | ZOUT_<br>EX[7] | ZOUT_<br>EX[6] | ZOUT_<br>EX[5] | ZOUT_<br>EX[4] | ZOUT_<br>EX[3] | ZOUT_<br>EX[2] | ZOUT_<br>EX[1] | ZOUT_<br>EX[0] | 0x00 | R | | 0x12 | ZOUT_<br>EX_H | ZOUT<br>Accelerometer<br>Data MSB | ZOUT_<br>EX[15] | ZOUT_<br>EX[14] | ZOUT_<br>EX[13] | ZOUT_<br>EX[12] | ZOUT_<br>EX[11] | ZOUT_<br>EX[10] | ZOUT_<br>EX[9] | ZOUT_<br>EX[8] | 0x00 | R | Table 19. Accelerometer LSB and MSB Registers ## **11.8 STATUS REGISTER** The status register contains the flag and status bits for sample acquisition and motion detection. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|----------|-----------------|--------------|-------|-------|------------------|----------------|---------------|-----------|---------------|--------------|-----| | 0x13 | STATUS_2 | Status Register | NEW_<br>DATA | Resv | Resv | TILT_35_<br>FLAG | SHAKE_<br>FLAG | ANYM_<br>FLAG | FLIP_FLAG | TILT_<br>FLAG | 0x00 | R | | Name | Description | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TILT_FLAG | This bit is active when the tilt feature in the motion control register (register 0x09, bit 0) is enabled. If polling is used, use the tilt interrupt in the interrupt status register (register 0x14, bit 0) instead because this bit can transition quickly. 1: Tilt condition is not detected. | | FLIP_FLAG | This bit is active when the flip feature in the motion control register (register 0x09, bit 0) is enabled. If polling is used, use the flip interrupt in the interrupt status register (register 0x14, bit 1) instead because this bit can transition quickly. O: Flip condition is not detected. 1: Flip condition is detected. | | ANYM_FLAG | This bit is active when the AnyMotion feature in the motion control register (register 0x09, bit 2) is enabled. If polling is used, use the AnyMotion interrupt in the interrupt status register (register 0x14, bit 2) instead because this bit can transition quickly. O: AnyMotion condition is not detected. 1: AnyMotion condition is detected. | | SHAKE_FLAG | This bit is active when the shake feature in the motion control register (register 0x09, bit 3) is enabled. If polling is used, use the shake interrupt in the interrupt status register (register 0x14, bit 3) instead because this bit can transition quickly. 0: Shake condition is not detected. 1: Shake condition is detected. | | TILT_35_FLAG | This bit is active when the tilt-35 feature in the motion control register (register 0x09, bit 4) is enabled. If polling is used, use the tilt-35 interrupt in the interrupt status register (register 0x14, bit 4) instead because this bit can transition quickly. 0: Tilt-35 condition is not detected. 1: Tilt-35 condition is detected. | | NEW_DATA | This bit is always active, only operates in WAKE mode, and is cleared and rearmed each time this register is read. This flag is set when XYZ data is written to registers 0x0D - 0x12. The host must poll this bit at the sample rate or faster to see this bit transition. O: No data has been generated by the sensor since the last read. 1: Data has been acquired and written to the output registers (0x0D - 0x12). | Table 20. Status Register ## 11.9 INTERRUPT STATUS REGISTER The interrupt status register reports the status of any pending interrupt sources. Each interrupt source must be enabled by the corresponding interrupt enable bit in register 0x06. All interrupts are cleared each time this register is read. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-----------------|------------------------------|---------|-------|-------|-----------------|---------------|--------------|----------|----------|--------------|-----| | 0x14 | INTR_<br>STAT_2 | Interrupt Status<br>Register | ACQ_INT | Resv | Resv | TILT_35_<br>INT | SHAKE_<br>INT | ANYM_<br>INT | FLIP_INT | TILT_INT | 0x00 | R | | Name | Description | |-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TILT_INT | This bit is active when the tilt feature in the interrupt enable register (register 0x06, bit 0) is enabled and the tilt/flip feature in the motion control register (register 0x09, bit 0) is enabled. | | | <ul><li>0: Tilt interrupt is not pending.</li><li>1: Tilt interrupt is pending.</li></ul> | | FLIP_INT | This bit is active when the flip feature in the interrupt enable register (register 0x06, bit 1) is enabled and the tilt/flip feature in the motion control register (register 0x09, bit 0) is enabled. | | _ | <ul><li>O: Flip interrupt is not pending.</li><li>1: Flip interrupt is pending.</li></ul> | | ANYM_INT | This bit is active when the AnyMotion feature in the interrupt enable register (register 0x06, bit 2) is enabled and the AnyMotion feature in the motion control register (register 0x09, bit 2) is enabled. <b>0</b> : AnyMotion interrupt is not pending. <b>1</b> : AnyMotion interrupt is pending. | | SHAKE_INT | This bit is active when the shake feature in the interrupt enable register (register 0x06, bit 3) is enabled, the shake feature in the motion control register (register 0x09, bit 3) is enabled, and the AnyMotion feature in the motion control register (register 0x09, bit 2) is enabled. O: Shake interrupt is not pending. 1: Shake interrupt is pending. | | TILT_35_INT | This bit is active when the tilt-35 feature in the interrupt enable register (register 0x06, bit 4) is enabled, the tilt-35 feature in the motion control register (register 0x09, bit 4) is enabled, and the AnyMotion feature in the motion control register (register 0x09, bit 2) is enabled. 1: Tilt-35 interrupt is pending. | | ACQ_INT | This bit only operates in WAKE mode. This bit is active when the interrupt feature in the interrupt enable register (register 0x06, bit 7) is enabled. 0: Sample interrupt is not pending. 1: Sample interrupt is pending. | **Table 21. Interrupt Status Register** ## 11.10 RANGE AND SCALE CONTROL REGISTER The range and scale control register sets the resolution, range, and filtering options for the accelerometer. All values are in sign-extended 2's complement format. Values are reported in registers 0x0D - 0x12 (the hardware formats the output). | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |--------------------------------------------------------------|-----------------------------------------|-------------------------|-------|----------|----------|----------|-----------------------|-------|-------|-----------------------|--------------|-----| | 0x20 | RANGE | Range Select<br>Control | Resv | RANGE[2] | RANGE[1] | RANGE[0] | <b>1</b> <sup>2</sup> | 01 | 01 | <b>1</b> <sup>2</sup> | 0x00 | w | | <sup>1</sup> Software must write a zero (0) to bits 1 and 2. | | | | | | | | | | | | | | <sup>2</sup> Softwa | Software must write a one (1) to bit 0. | | | | | | | | | | | | | Name | Description | |------------|-------------------------------------------------------------------------| | | Resolution range of the accelerometer, based on the current resolution. | | | <b>000</b> : ± 2g | | | <b>001</b> : ± 4g | | | <b>010</b> : ±8g | | RANGE[2:0] | <b>011</b> : ± 16g | | | <b>100</b> : ± 12g | | | 101: Reserved. | | | 110: Reserved. | | | 111: Reserved. | Table 22. Range and Scale Control Register ## 11.11 X-AXIS DIGITAL OFFSET REGISTERS The X-axis digital offset registers contains a signed 2's complement 14-bit value used to offset the output of the X-axis filter. These registers are loaded from the OTP at device initialization and POR. If necessary, these values can be overwritten by software. Register 0x22 bit 7 is the ninth bit of X-axis gain (XGAIN). See **X-Axis Digital Gain Registers** for more information about XGAIN. **NOTE:** When modifying these registers with new gain or offset values, software should perform a read-modify-write type of access to ensure that unrelated bits do not get changed. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-------|-----------------|----------|----------|----------|----------|----------|----------|---------|---------|--------------|-----| | 0x21 | XOFFL | X-Offset<br>LSB | 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 | XGAIN[8] | XOFF[14] | XOFF[13] | XOFF[12] | XOFF[11] | XOFF[10] | XOFF[9] | XOFF[8] | Per chip | W | Table 23. X-Axis Digital Offset Registers ## 11.12 Y-AXIS DIGITAL OFFSET REGISTERS The Y-axis digital offset registers contains a signed 2's complement 14-bit value used to offset the output of the Y-axis filter. These registers are loaded from the OTP at device initialization and POR. If necessary, these values can be overwritten by software. Register 0x24 bit 7 is the ninth bit of Y-axis gain (YGAIN). See <u>Y-Axis Digital Gain Registers</u> for more information about YGAIN. **NOTE:** When modifying these registers with new gain or offset values, software should perform a read-modify-write type of access to ensure that unrelated bits do not get changed. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-------|-----------------|----------|----------|----------|----------|----------|----------|---------|---------|--------------|-----| | 0x23 | YOFFL | Y-Offset<br>LSB | 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 | YGAIN[8] | YOFF[14] | YOFF[13] | YOFF[12] | YOFF[11] | YOFF[10] | YOFF[9] | YOFF[8] | Per chip | W | Table 24. Y-Axis Digital Offset Registers #### 11.13 Z-AXIS DIGITAL OFFSET REGISTERS The Z-axis digital offset registers contains a signed 2's complement 14-bit value used to offset the output of the Z-axis filter. These registers are loaded from the OTP at device initialization and POR. If necessary, these values can be overwritten by software. Register 0x26 bit 7 is the ninth bit of Z-axis gain (ZGAIN). See **Z-Axis Digital Gain Registers** for more information about ZGAIN. **NOTE:** When modifying these registers with new gain or offset values, software should perform a read-modify-write type of access to ensure that unrelated bits do not get changed. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-------|-----------------|----------|----------|----------|----------|----------|----------|---------|---------|--------------|-----| | 0x25 | ZOFFL | Z-Offset<br>LSB | 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 | ZGAIN[8] | ZOFF[14] | ZOFF[13] | ZOFF[12] | ZOFF[11] | ZOFF[10] | ZOFF[9] | ZOFF[8] | Per chip | W | **Table 25. Z-Axis Digital Offset Registers** #### 11.14 X-AXIS DIGITAL GAIN REGISTERS The X-axis digital gain registers contains an unsigned 9-bit value. These registers are loaded from the OTP at device initialization and POR. If necessary, these values can be overwritten by software. Register 0x22 bit 7 is the ninth bit of XGAIN. **NOTE:** When modifying these registers with new gain values, software should perform a read-modify-write type of access to ensure that unrelated bits do not get changed. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-------|-----------------|----------|----------|----------|----------|----------|----------|----------|----------|--------------|-----| | 0x22 | XOFFH | X-Offset<br>MSB | XGAIN[8] | XOFF[14] | XOFF[13] | XOFF[12] | XOFF[11] | XOFF[10] | XOFF[9] | XOFF[8] | Per chip | W | | 0x27 | XGAIN | X Gain | XGAIN[7] | XGAIN[6] | XGAIN[5] | XGAIN[4] | XGAIN[3] | XGAIN[2] | XGAIN[1] | XGAIN[0] | Per chip | W | Table 26. X-Axis Digital Gain Registers #### 11.15 Y-AXIS DIGITAL GAIN REGISTERS The Y-axis digital gain registers contains an unsigned 9-bit value. These registers are loaded from the OTP at device initialization and POR. If necessary, these values can be overwritten by software. Register 0x24 bit 7 is the ninth bit of YGAIN. **NOTE:** When modifying these registers with new gain values, software should perform a read-modify-write type of access to ensure that unrelated bits do not get changed. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-------|-----------------|----------|----------|----------|----------|----------|----------|----------|----------|--------------|-----| | 0x24 | YOFFH | Y-Offset<br>MSB | YGAIN[8] | YOFF[14] | YOFF[13] | YOFF[12] | YOFF[11] | YOFF[10] | YOFF[9] | YOFF[8] | Per chip | W | | 0x28 | YGAIN | Y Gain | YGAIN[7] | YGAIN[6] | YGAIN[5] | YGAIN[4] | YGAIN[3] | YGAIN[2] | YGAIN[1] | YGAIN[0] | Per chip | W | **Table 27. Y-Axis Digital Offset Registers** #### 11.16 Z-AXIS DIGITAL GAIN REGISTERS The Z-axis digital gain registers contains an unsigned 9-bit value. These registers are loaded from the OTP at device initialization and POR. If necessary, these values can be overwritten by software. Register 0x26 bit 7 is the ninth bit of ZGAIN. **NOTE:** When modifying these registers with new gain values, software should perform a read-modify-write type of access to ensure that unrelated bits do not get changed. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-------|-----------------|----------|----------|----------|----------|----------|----------|----------|----------|--------------|-----| | 0x26 | ZOFFH | Z-Offset<br>MSB | ZGAIN[8] | ZOFF[14] | ZOFF[13] | ZOFF[12] | ZOFF[11] | ZOFF[10] | ZOFF[9] | ZOFF[8] | Per chip | W | | 0x29 | ZGAIN | Z Gain | ZGAIN[7] | ZGAIN[6] | ZGAIN[5] | ZGAIN[4] | ZGAIN[3] | ZGAIN[2] | ZGAIN[1] | ZGAIN[0] | Per chip | W | **Table 28. Z-Axis Digital Offset Registers** #### 11.17 TILT/FLIP THRESHOLD REGISTERS The tilt/flip threshold registers are used for both the flat/tilt/flip and tilt-35 algorithms. For the flat/tilt/flip algorithm, these registers hold the programmed 15-bit threshold value to detect the flat/tilt/flip position of the device. If the sample value is greater than the programmed value of these registers, a tilt condition is detected. If the sample value is less than the programmed value of these registers, a flat/flip condition is detected. A flat/flip condition is dependent on the Z-axis value and the Z-axis orientation bit (register 0x09, bit 5). For the tilt-35 algorithm, these registers hold the programmed 15-bit threshold value that defines the amount of tilt to detect. When the programmed tilt is detected, the tilt-35 interrupt is set in the interrupt status registers (register 0x14, bit 4). | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-----------------------|----------------------------|-----------|----------------|----------------|----------------|----------------|----------------|-----------|---------------|--------------|-----| | 0x40 | TF_<br>THRESH_<br>LSB | Tilt/Flip<br>Threshold LSB | TF_THR[7] | TF_THR[6] | TF_THR[5] | TF_THR[4] | TF_THR[3] | TF_THR[2] | TF_THR[1] | TF_<br>THR[0] | 0x00 | W | | 0x41 | TF_<br>THRESH_<br>MSB | Tilt/Flip<br>Threshold MSB | Resv | TF_<br>THR[14] | TF_<br>THR[13] | TF_<br>THR[12] | TF_<br>THR[11] | TF_<br>THR[10] | TF_THR[9] | TF_<br>THR[8] | 0x00 | W | Table 29. Tilt/Flip Threshold Registers ## 11.18 TILT/FLIP DEBOUNCE REGISTER The tilt/flip debounce register holds the programmed 8-bit duration of a tilt/flip. When a tilt/flip condition is detected and the duration of the condition is greater than the programmed value of this register, the tilt/flip interrupt is set in the interrupt status registers (register 0x14, bits 0 and 1). | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-------|-----------------------|----------|----------|----------|----------|----------|----------|----------|----------|--------------|-----| | 0x42 | TF_DB | Tilt/Flip<br>Debounce | TF_DB[7] | TF_DB[6] | TF_DB[5] | TF_DB[4] | TF_DB[3] | TF_DB[2] | TF_DB[1] | TF_DB[0] | 0x00 | W | Table 30. Tilt/Flip Debounce Register ### 11.19 ANYMOTION THRESHOLD REGISTERS The Anymotion threshold registers hold the programmed 15-bit threshold value to detect a change in the position of the device. If the change in position between the current sample value and previous sample value on any axis is greater than the programmed value of this register, an AnyMotion condition is detected. When the change in position exceeds the programmed AnyMotion threshold, the AnyMotion interrupt is set in the interrupt status registers (register 0x14, bit 2). | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-----------------------|----------------------------|-----------------|------------------|------------------|------------------|------------------|------------------|-----------------|-----------------|--------------|-----| | 0x43 | AM_<br>THRESH_<br>LSB | AnyMotion<br>Threshold LSB | ANYM_<br>THR[7] | ANYM_<br>THR[6] | ANYM_<br>THR[5] | ANYM_<br>THR[4] | ANYM_<br>THR[3] | ANYM_<br>THR[2] | ANYM_<br>THR[1] | ANYM_<br>THR[0] | 0x00 | W | | 0x44 | AM_<br>THRESH_<br>MSB | AnyMotion<br>Threshold MSB | Resv | ANYM_<br>THR[14] | ANYM_<br>THR[13] | ANYM_<br>THR[12] | ANYM_<br>THR[11] | ANYM_<br>THR[10] | ANYM_<br>THR[9] | ANYM_<br>THR[8] | 0x00 | W | **Table 31. AnyMotion Threshold Registers** ## 11.20 ANYMOTION DEBOUNCE REGISTER The AnyMotion debounce register holds the programmed 8-bit duration of any motion. After an AnyMotion condition is detected, if another AnyMotion condition is not detected for the programmed duration, the AnyMotion interrupt is cleared in the interrupt status registers (register 0x14, bits 0 and 1). | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |-------|-------|-------------|-------|-------|-------|-------|-------|-------|-------|-------|--------------|-----| | 0x45 | AM DB | AnyMotion | ANYM_ 0x00 | w | | OX 13 | /55 | Debounce | DB[7] | DB[6] | DB[5] | DB[4] | DB[3] | DB[2] | DB[1] | DB[0] | ONOO | '' | Table 32. AnyMotion Debounce Register ## 11.21 SHAKE THRESHOLD REGISTERS The shake threshold registers hold the programmed 15-bit threshold value to detect a shake. If the change in position between the current sample value and previous sample value on any axis is greater than the programmed value of this register, a shake condition is detected. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|------------------------|------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|-----| | 0x46 | SHK_<br>THRESH_<br>LSB | Shake Threshold<br>LSB | SH _<br>THR[7] | SH _<br>THR[6] | SH _<br>THR[5] | SH _<br>THR[4] | SH_<br>THR[3] | SH _<br>THR[2] | SH _<br>THR[1] | SH _<br>THR[0] | 0x00 | W | | 0x47 | SHK_<br>THRESH_<br>MSB | Shake Threshold<br>MSB | SH_<br>THR[15] | SH_<br>THR[14] | SH_<br>THR[13] | SH_<br>THR[12] | SH_<br>THR[11] | SH_<br>THR[10] | SH _<br>THR[9] | SH _<br>THR[8] | 0x00 | W | **Table 33. Shake Threshold Registers** ### 11.22 SHAKE DURATION, PEAK-TO-PEAK REGISTERS The shake duration and peak-to-peak registers hold the programmed 12-bit threshold value of a peak and the peak-to-peak width of a shake and the programmed 3-bit threshold value of the shake counter. The data in these registers and the shake threshold registers is used to determine if the shake interrupt should be set. If a shake condition is detected, the shake counter is incremented and the shake's peak is detected and measured. If the peak's width is greater than the peak threshold set in this register, the shake counter continues to increment (measuring the duration of the peak event). When a shake condition is no longer detected, the peak-to-peak event is measured and the shake counter continues to increment (measuring the duration of the peak-to-peak event). When the peak-to-peak threshold is surpassed, the shake counter continues to increment, measuring the duration of the peak event. The shake counter continues to increment each time a peak or peak-to-peak threshold is surpassed. When the shake counter threshold is surpassed, the shake interrupt is set in the interrupt status registers (register 0x14, bit 3). | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-----------------------------------|----------------------------------------------------|-------------------|--------------------|--------------------|--------------------|--------------------|--------------------|-------------------|-------------------|--------------|-----| | 0x48 | PK_P2P_<br>DUR_<br>THRESH_<br>LSB | Peak-to-Peak<br>Duration LSB | PK_P2P_<br>DUR[7] | PK_P2P_<br>DUR[6] | PK_P2P_<br>DUR[5] | PK_P2P_<br>DUR[4] | PK_P2P_<br>DUR[3] | PK_P2P_<br>DUR[2] | PK_P2P_<br>DUR[1] | PK_P2P_<br>DUR[0] | 0x00 | w | | 0x49 | PK_P2P_<br>DUR_<br>THRESH_<br>MSB | Shake Duration<br>and Peak-to-Peak<br>Duration MSB | Resv | SHK_CNT_<br>DUR[2] | SHK_CNT_<br>DUR[1] | SHK_CNT_<br>DUR[0] | PK_P2P_<br>DUR[11] | PK_P2P_<br>DUR[10] | PK_P2P_<br>DUR[9] | PK_P2P_<br>DUR[8] | 0x00 | W | Table 34. Shake Duration and Peak-to-Peak Registers ## 11.23 TIMER CONTROL REGISTER The timer control register sets the period or duration of two features driven by the 10 Hz low speed clock. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|----------------|---------------|-------------------------|--------------------|--------------------|--------------------|-------|----------------|------------|----------------|--------------|-----| | 0x4A | TIMER_<br>CTRL | Timer Control | TEMP_<br>PER_INT_<br>EN | TEMP_<br>PERIOD[2] | TEMP_<br>PERIOD[1] | TEMP_<br>PERIOD[0] | Resv | TILT_<br>35[2] | TILT_35[1] | TILT_<br>35[0] | 0x00 | w | | Name | Description | |------------------|---------------------------------------------------------------------| | | Duration of a valid tilt-35 angle detection. | | | <b>000</b> : 1.6 s (default) | | | <b>001</b> : 1.8 s | | | <b>010</b> : 2.0 s | | TILT_35[2:0] | <b>011</b> : 2.2 s | | | <b>100</b> : 2.4 s | | | <b>101</b> : 2.6 s | | | <b>110</b> : 2.8 s | | | <b>111</b> : 3.0 s | | | Timeout or re-arm time for the temporary latch on the TEST_INT pin. | | | <b>000</b> : 200 ms (default) | | | <b>001</b> : 400 ms | | | <b>010</b> : 800 ms | | TEMP_PERIOD[2:0] | <b>011</b> : 1600 ms | | | <b>100</b> : 3200 ms | | | <b>101</b> : 6400 ms | | | 110: Reserved | | | 111: Reserved | | | Temporary latch. | | TEMP_PER_INT_EN | <b>0</b> : The temporary latch feature is disabled (default). | | | 1: The temporary latch feature is enabled. | **Table 35. Timer Control Register** # 12 INDEX OF TABLES | Table 1. Order Information | 4 | |----------------------------------------------------|----| | Table 2. Package Information | 4 | | Table 3. Pin Description | 8 | | Table 4. Absolute Maximum Ratings | 15 | | Table 5. Sensor Characteristics | 16 | | Table 6. Electrical Characteristics | | | Table 7. I2C Electrical and Timing Characteristics | | | Table 8. I2C Timing Characteristics | 19 | | Table 9. Summary of Resolution, Range, and Scaling | 20 | | Table 10. Operational States | 23 | | Table 11. Forcing Operational States | 24 | | Table 12. I2C Address Selection | 27 | | Table 13. Register Summary | 31 | | Table 14. Device Status Register | | | Table 15. Interrupt Enable Register | 33 | | Table 16. Mode Register States | 34 | | Table 17. Sample Rate Register | 35 | | Table 18. Motion Control Register | 36 | | Table 19. Accelerometer LSB and MSB Registers | | | Table 20. Status Register | 38 | | Table 21. Interrupt Status Register | 39 | | Table 22. Range and Scale Control Register | 40 | | Table 23. X-Axis Digital Offset Registers | 41 | | Table 24. Y-Axis Digital Offset Registers | 42 | | Table 25. Z-Axis Digital Offset Registers | 43 | | Table 26. X-Axis Digital Gain Registers | 44 | | Table 27. Y-Axis Digital Offset Registers | 45 | | Table 28. Z-Axis Digital Offset Registers | 46 | | Table 29. Tilt/Flip Threshold Registers | 47 | | Table 30. Tilt/Flip Debounce Register | 48 | | Table 31. AnyMotion Threshold Registers | 49 | | Table 32. AnyMotion Debounce Register | 50 | | NELIGIO 1100 (10 P.V.) 0 1 | | | Table 33. Shake Threshold Registers | 51 | |-----------------------------------------------------|----| | Table 34. Shake Duration and Peak-to-Peak Registers | 52 | | Table 35. Timer Control Register | 53 | # 13 REVISION HISTORY | Date | Revision | Description | |---------|--------------------|-------------------------------------------------------------------| | 2017-11 | APS-045-0020v1.01 | Initial release | | 2018-04 | APS-045-0020v2.0 | Removed preliminary | | 2020-08 | APS-045-0020v2.1 | Change to MEMSIC format based on the License Agreement with mCube | | 2021-04 | APS-045-0020v2.2 | Update Tape & Reel, 10Ku | | 2022-05 | APS-045-0020v2.2.1 | I2C Timing update |