#### GENERAL DESCRIPTION The MC3479 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 MC3479 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 MC3479 the internal sample rate can be set from 0.5 to 1000 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 single sample resolution - 16-bit resolution with FIFO - 0.5 to 1000 Hz Output Data Rate - 4 μA typical Standby current - Low typical active current ### Simple System Integration - SPI, up to 10 MHz - 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** - Smartphone - Wearable - IoT & IoMT - Remote controls, gaming - Vibration in Cell phone - VR & game controllers # TABLE OF CONTENTS | 1 | | Orc | der Information | 5 | |---|-----|------|-----------------------------------------------|------| | 2 | | Fur | nctional Block Diagram | 6 | | 3 | | Pad | ckaging and Pin Description | 7 | | | 3.1 | | Package Outline | 7 | | | 3.2 | | Package Orientation | 8 | | | 3.3 | | Pin Description | 9 | | | 3.4 | | Typical Application Circuits | . 10 | | | 3.5 | | Tape and Reel | . 13 | | | 3.6 | | Soldering Profile | . 15 | | | 3.7 | | Shipping and Handling Guidelines | . 15 | | | 3.8 | | Moisture Sensitivity Level Control | . 15 | | 4 | | Spe | ecifications | . 16 | | | 4.1 | | Absolute Maximum Ratings | . 16 | | | 4.2 | | Sensor Characteristics | . 17 | | | 4.3 | | Electrical and Timing Characteristics | . 18 | | | 4.3 | 3.1 | Electrical Power and Internal Characteristics | . 18 | | | 4.3 | 3.2 | Electrical Characteristics | . 19 | | | 4.3 | 3.3 | I2C Timing Characteristics | . 20 | | | 4.3 | 3.4 | SPI Timing Characteristics | . 21 | | 5 | | Gei | neral Operation | . 22 | | | 5.1 | | Sensor Sampling | . 22 | | | 5.2 | | Offset and Gain Calibration | . 22 | | 6 | | Ope | erational States | 23 | | 7 | | Оре | erational State Flow | . 24 | | 8 | | Inte | errupts | 25 | | | 8.1 | | Interrupt Overview | . 25 | | | 8.2 | | Enabling and Clearing Interrupts | . 26 | | | 8.3 | | Interrupt Sources | . 26 | | | 8.3 | 3.1 | ACQ_INT Interrupt | . 26 | | | 8.3 | 3.2 | TILT/FLIP (TILT_INT, FLIP_INT) | . 26 | | | 8.3 | 3.3 | Interrupt on AnyMotion (ANYM_INT) | . 26 | | | 8.3 | 3.4 | Interrupt on SHAKE (SHAKE_INT) | . 26 | | | | | | | # MC3479 3-Axis Accelerometer | | 8.3.5 | Interrupt on TILT_35 (TILT_35_INT) | 27 | |----|-------|-----------------------------------------------|----| | | 8.3.6 | Interrupt on FIFO Empty (FIFO_EMPTY_INT) | 27 | | | 8.3.7 | Interrupt on FIFO Full (FIFO_FULL_INT) | 27 | | | 8.3.8 | Interrupt on FIFO Threshold (FIFO_THRESH_INT) | 27 | | 8 | 3.4 | Interrupt Servicing | 28 | | | 8.4.1 | Global Interrupt Service method | 28 | | | 8.4.2 | Bitmask/Individual Interrupt Service Mode | 28 | | 8 | 3.5 | Interrupt Requests and External INT Pins | 30 | | | 8.5.1 | Selecting Drive and Polarity | 30 | | | 8.5.2 | Swapping INT Pins | 31 | | | 8.5.3 | Combining Interrupt Requests | 31 | | 9 | San | npling | 32 | | Ş | ).1 | Continuous Sampling | 32 | | ç | 0.2 | Setting the Sample Rate | 32 | | ç | 0.3 | Additional Rate Options | 33 | | 10 | I2C | Interface | 35 | | 1 | 0.1 | Physical Interface | 35 | | 1 | 0.2 | Timing | 36 | | 1 | 0.3 | I2C Message Format | 36 | | 1 | 0.4 | I2C Watchdog Timer | 37 | | 11 | SPI | Interface | 38 | | 1 | 1.1 | SPI Physical Interface | 38 | | 1 | 1.2 | SPI Protocol | 38 | | 1 | 1.3 | SPI Register Write Cycle - Single | 38 | | 1 | 1.4 | SPI Register Write Cycle - Burst | 38 | | 1 | 1.5 | SPI Register Read Cycle - Single | 39 | | 1 | 1.6 | SPI Register Read Cycle - Burst | 39 | | 12 | Reg | gister Interface | 40 | | 1 | 2.1 | Register Summary | 40 | | 1 | 2.2 | (0x05)Device Status Register | 43 | | 1 | 2.3 | (0x06) Interrupt Enable Register | 44 | | 1 | 2.4 | (0x07) Mode Register | 45 | | 1 | 2.5 | (0x08) Sample Rate Register | 46 | | 1 | 2.6 | (0x09) Motion Control Register | 47 | | 1 | 2.7 | (0x0A) FIFO Status Register | 48 | # MC3479 3-Axis Accelerometer | | 12.8 | (0x0B) FIFO Read Pointer Register | 49 | |---|------|------------------------------------------------------------------|----| | | 12.9 | (0x0C) FIFO Write Pointer Register | 50 | | | 12.1 | 0 (0x0D - 0x12) XOUT, YOUT and ZOUT Data Accelerometer Registers | 51 | | | 12.1 | 1 (0x13) Status Register | 52 | | | 12.1 | 2 (0x14) Interrupt Status Register | 53 | | | 12.1 | 3 (0x20) Range and Scale Control Register | 55 | | | 12.1 | 4 (0x21 – 0x22) X-Axis Digital Offset Registers | 56 | | | 12.1 | 5 (0x23 – 0x24) Y-Axis Digital Offset Registers | 57 | | | 12.1 | 6 (0x25 – 0x26) Z-Axis Digital Offset Registers | 58 | | | 12.1 | 7 (0x22 & 0x27) X-Axis Digital Gain Registers | 59 | | | 12.1 | 8 (0x24 & 0x28) Y-Axis Digital Gain Registers | 60 | | | 12.1 | 9 (0x26 & 0x29) Z-Axis Digital Gain Registers | 61 | | | 12.2 | 0 (0x2D) FIFO Control Register | 62 | | | 12.2 | 1 (0x2E) FIFO Threshold Register | 64 | | | 12.2 | 2 (0x2F) FIFO Interrupt Status Register | 65 | | | 12.2 | 3 (0x30) FIFO Control Register2, Sample Rate Register 2 | 66 | | | 12.2 | 4 (0x31) Communication Control Register | 68 | | | 12.2 | 5 (0x33) GPIO Control Register | 69 | | | 12.2 | 6 (0x40 – 0x41) Tilt/Flip Threshold Registers | 70 | | | 12.2 | 7 (0x42) Tilt/Flip Debounce Register | 71 | | | 12.2 | 8 (0x43 – 0x44) AnyMotion Threshold Registers | 72 | | | 12.2 | 9 (0x45) AnyMotion Debounce Register | 73 | | | 12.3 | 0 (0x46 – 0x47) Shake Threshold Registers | 74 | | | 12.3 | 1 (0x48 – 0x49) Shake Duration, Peak-to-Peak Registers | 75 | | | 12.3 | 2 (0x4A) Timer Control Register | 76 | | | 12.3 | 3 (0x4B) Read Count Register | 77 | | 1 | 3 | Index of Tables | 78 | | 1 | 4 | Revision History | 80 | | 1 | 5 | Legal | 81 | # 1 ORDER INFORMATION **Table 1. Order Information** | Part Number | Resolution | Order Number | Package | Shipping | |-------------|------------|--------------|---------|------------------| | MC3479 | 16-bit | MC3479 | VLGA-12 | Tape & Reel, 5Ku | **Table 2. Package Information** # **2 FUNCTIONAL BLOCK DIAGRAM** Figure 1. Block Diagram # **3 PACKAGING AND PIN DESCRIPTION** ### 3.1 PACKAGE OUTLINE 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 | SCK_SCL <sup>1</sup> | I2C/SPI serial clock input | | | | 2 | CSN | SPI chip select (active low) | | | | 3 | DOUT_A6 | SPI data output<br>I2C address bit 6 | | | | 4 | DIN_SDA <sup>1</sup> | SPI data In<br>I2C serial data input/output | | | | 5 | NC | No connect | | | | 6 | GND | Ground | | | | 7 | VPP | Connect to GND | | | | 8 | NC | No connect | | | | 9 | VDD | Power supply for internal | | | | 10 | NC | No Connect | | | | 11 | INTN 2 <sup>2,3</sup> | Interrupt active LOW 3 | | | | 12 | INTN 1 <sup>2,3</sup> | Interrupt active LOW <sup>3</sup> | | | **Table 3. Pin Description** ### Notes: - 1) This pin requires a pull-up resistor, typically $4.7k\Omega$ to pin VDD. 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 (see GPIO control register, address 0x33). If set to open-drain, then it requires a pull-up resistor, typically $4.7k\Omega$ to VDD. - 3) INTN pin polarity is programmable in the GPIO control register, address 0x33. ### 3.4 TYPICAL APPLICATION CIRCUITS NOTE<sup>1</sup>: Rp are typically $4.7k\Omega$ pullup resistors to VDDIO, per I2C specification. When VDDIO is powered down, DIN\_SDA and SCK\_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 I2C 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 VDD pin. NOTE Rp: Attach typical $4.7k\Omega$ pullup resistor if INTN is defined as open-drain. Figure 6. Typical 4-wire SPI Application Circuit NOTE Rp: Attach typical $4.7k\Omega$ pullup resistor if INTN is defined as open-drain. Figure 7. Typical 3-wire SPI Application Circuit ### 3.5 TAPE AND REEL Devices are shipped in reels, in standard cardboard box packaging. See <u>Figure 8. MC3479 Tape Dimensions</u> and <u>Figure 9. MC3479 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. MC3479 Tape Dimensions • Dimensions in mm. Figure 9. MC3479 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 mCube document, PCB Design, Device Handling and Assembly Guidelines, document number AN-001, 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 mCube document, PCB Design, Device Handling and Assembly Guidelines, document number AN-001, 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 /<br>Maximum Value | Unit | |---------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------|----------| | Supply Voltages | Pin VDD | -0.3 / +3.6 | V | | Ambient operating temperature | T <sub>OP</sub> | -40 / +85 | 0C | | Storage temperature | T <sub>STG</sub> | -40 / +125 | °C | | 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 CSN,<br>DIN_SDA,<br>DOUT_A6, INTN 1,<br>INTN 2, and<br>SCK_SCL | -0.3 / (VDD + 0.3) or<br>3.6 whichever is lower | <b>V</b> | **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 ≤ T <sub>op</sub> ≤ +85 <sup>0</sup> 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 = 125 Hz, LPF = ODR/16 | | 0.7 (X,Y)<br>1.3 (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 | | 0.5 | | 1000 | Hz | | | <sup>1</sup> Values are based on device | characterization, not tested in prod | 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 | 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 = 100 Hz | | 77 | | μΑ | | Pad Leakage | Per I/O pad | -1 | 0.01 | 1 | μA | | 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 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 1 or INTN 2, lol ≤ 2 mA | Vol<br>Voh | 0 | 0.4<br>0.9*VDD | V | | Output voltage, pin DIN_SDA (open drain),<br>lol ≤ 1 mA | Vols | - | 0.1*VDD | V | | Input current, pins DIN_SDA and SCK_SCL (input voltage between 0.1*VDD and 0.9*VDD max) | li | -10 | 10 | μΑ | | Capacitance, pins DIN_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. Electrical and Timing Characteristics - Interface ### NOTES: - If multiple slaves are connected to the I2C signals in addition to this device, only 1 pull-up resistor on each of DIN\_SDA and SCK\_SCL should exist. Also, care must be taken to not violate the I2C specification for capacitive loading. - When pin VDD 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 | | | | dard<br>ode | Fast I | Mode | 1 0.00 | Mode<br>us | | |----------------------|--------------------------------------------|-----|-------------|--------|------|--------|------------|-------| | 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; STA</sub> | 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 | 5.0 | - | - | - | - | - | μ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. ### 4.3.4 SPI TIMING CHARACTERISTICS Figure 11. SPI Interface Timing Waveform | Symbol | Parameter | Value | | Units | |---------|---------------------------------|-------|-----|-------| | | | Min | Max | | | tc | SPI SCK_SCL Clock Cycle | 500 | | ns | | fc | SPI SCK_SCL Clock Frequency | | 10 | MHz | | tcs_su | SPI CSN Setup Time | 6 | | ns | | tcs_hld | SPI CSN Hold Time | 8 | | ns | | tdi_su | SPI DIN_SDA Input Setup Time | 5 | | ns | | tdi_hld | SPI DIN_SDA Input Hold Time | 15 | | ns | | tdo_vld | SPI DOUT_A6 Valid Output Time | | 50 | ns | | tdo_hld | SPI DOUT_A6 Output Hold Time | 9 | | ns | | tdo_dis | SPI DOUT_A6 Output Disable Time | | 50 | ns | **Table 9. SPI Interface Timing Parameters** # **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 0.5 and 1000 samples/second. See the <u>Sample Rate Register</u> 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 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 complement | | | ± 4g | ~.122 | (-32768) | (+32767) | number, results in XOUT_EX, | | | ± 8g | ~.244 | | | ZOUT_EX. The MSB is | | | ± 12g | ~.366 | | | the sign bit. | | | ± 16g | ~.488 | | | (Integer interpretation also shown) | Table 10. 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. # **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/SPI<br>Bus | Description | | | | | |---------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | | Lowest power consumption | | | | | | | | Internal clocking is halted | | | | | | | | No motion detection, sampling, or calibration | | | | | | STANDBY | R/W | <ul> <li>The I2C/SPI bus can read and write to registers (resolution, range,<br/>thresholds and other settings can be changed)</li> </ul> | | | | | | | | Reset not allowed | | | | | | | | Default state after a power-up | | | | | | | R | Highest power consumption | | | | | | | | Internal clocking is enabled | | | | | | WAKE | | Continuous motion detection and sampling; automatic calibration is available | | | | | | | | The I2C/SPI bus can only write to the mode register and read all other registers | | | | | | | | Reset allowed | | | | | **Table 11. Operational States** # 7 OPERATIONAL STATE FLOW <u>Figure 12. Operational State Flow</u> shows the operational state flow for the device. The device defaults to STANDBY following power-on. Figure 12. 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 mCube 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 | | Torce STANDBT State | 31A1L[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 12. Forcing Operational States** ### 8 INTERRUPTS The sensor device utilizes output pin INTN 1 or INTN 2 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 INTN 1 or INTN 2 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 for the sensor to update the sample data registers. ### 8.1 INTERRUPT OVERVIEW | Feature | Description | Comment | | |-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Interrupt Pins | Two interrupt pins are supported: INTN1 INTN2 | INTN1 defaults to open-drain mode, active low polarity, and transitions on SAMPLE+MOTION interrupt events. INTN2 defaults to open-drain mode, active low polarity, and transitions on FIFO interrupt events | | | Interrupt Polarity INTN1 and INTN2 pins operate in open-drain and active-drive modes. The polarity of the interrupts is independently selectable. | | The interrupt polarity/drive mode bits are in the GPIO control register 0x33. | | | Interrupt Sources | 1 interrupt on sample 5 motion interrupts 3 FIFO interrupts | The default setting is to route SAMPLE+MOTION interrupt requests (INT1_REQ) to INTN1 pin and FIFO interrupt requests (INT2_REQ) to the INTN2 pin. | | | Interrupt Servicing | Interrupts may be cleared globally or individually. All interrupts are cleared by <b>writing</b> to register 0x14. FIFO interrupt bits are loaded in register 0x2F. | Global clearing is the default, use register 0x31 bit 6 (INDIV_INTR_CLR) to enable the individual interrupt clear option (bitmask mode). Read/writing to register 0x2F does not clear FIFO interrupts. | | | Swapping or Combining Interrupt Requests | INT1_REQ (sample + motion) and INT2_REQ (FIFO) may be swapped between the INTN1 and INTN2 pins or combined on a single INTN1 pin. | If all interrupts are combined in a single source, the pin to be used can still be chosen by using register 0x31 bit 4, INTN1 or INTN2. | | **Table 13. Interrupt Overview** ### 8.2 ENABLING AND CLEARING INTERRUPTS The <u>interrupt status register</u> (0x14) contains the bits for the sample acquisition interrupt ACQ\_INT and the motion interrupts. The FIFO interrupt status register (0x2F) contains the bits for the FIFO interrupts The <u>interrupt enable register</u> (0x06) and FIFO control register (0x2D) determine if a flag event generates interrupts. The interrupts are cleared and rearmed every time the interrupt status register (0x14) is written. Interrupts may be cleared globally or individually. 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 signals may be chosen by setting the INTN1 or INTN2 IPP and IAH bits in the GPIO control register (0x33). #### 8.3 INTERRUPT SOURCES ### 8.3.1 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. ### 8.3.2 TILT/FLIP (TILT\_INT, FLIP\_INT) The TILT and FLIP flag bits in register 0x03/0x13 bit are active when the TILT/FLIP features are enabled by register 0x9 bit 0. The flag bits can transition quickly, so polled operation may be difficult. It is recommended to use the interrupt register 0x14 bits 0 or 1 instead. Note that the TILT and FLIP interrupt enables in register 0x06 bits [1:0] are separate, although there is a single control bit in register 0x09. ### 8.3.3 INTERRUPT ON ANYMOTION (ANYM\_INT) The ANYM flag bit in register 0x03/0x13 bit is active when the ANYM feature is enabled by register 0x9 bit 2. The flag bit can transition quickly, so polled operation may be difficult. It is recommended to use the interrupt in register 0x14 bit 2 instead. Note that the SHAKE and TILT\_35 interrupts require the ANYM feature to be enabled in register 0x09 bit 2, but the ANYM interrupt enable in register 0x06 bit 2 is not required. ### 8.3.4 INTERRUPT ON SHAKE (SHAKE\_INT) The SHAKE flag bit in register 0x03/0x13 bit is active when the SHAKE feature is enabled by register 0x9 bit 3. The flag bit can transition quickly, so polled operation may be difficult. It is recommended to use the interrupt register 0x14 bit 3 instead. Note that the SHAKE interrupt requires the ANYM feature to be enabled in register 0x09 bit 2, but the ANYM interrupt enable in register 0x06 bit 2 is not required. ### 8.3.5 INTERRUPT ON TILT\_35 (TILT\_35\_INT) The TILT\_35 flag bit in register 0x03/0x13 bit is active when the SHAKE feature is enabled by register 0x9 bit 4. The flag bit can transition quickly, so polled operation may be difficult. It is recommended to use the interrupt register 0x14 bit 4 instead. Note that the TILT\_35 interrupt requires the ANYM feature to be enabled in register 0x09 bit 2, but the ANYM interrupt enable in register 0x06 bit 2 is not required. ### 8.3.6 INTERRUPT ON FIFO EMPTY (FIFO EMPTY INT) The FIFO\_EMPTY flag bit in register 0x0A bit 0 is active when the FIFO enable (FIFO\_EN) control is enabled in register 0x2D bit 5. The FIFO\_EMPTY flag will be set to '1' following a POR or SW\_RESET because the default state of the FIFO is empty. Note that the FIFO\_EMPTY bit may transition on any write or read to the FIFO. The FIFO\_EMPTY\_INT\_EN interrupt control bit is at register 0x2D bit 0. No bits in register 0x06 are required to be set. ### 8.3.7 INTERRUPT ON FIFO FULL (FIFO\_FULL\_INT) The FIFO\_FULL flag bit in register 0x0A bit 1 is active when the FIFO enable (FIFO\_EN) control is enabled in register 0x2D bit 5. The FIFO\_FULL flag will be set to '0' following a POR or SW\_RESET because the default state of the FIFO is empty. Note that the FIFO\_FULL bit may transition on any write or read to the FIFO. The FIFO\_FULL\_INT\_EN interrupt control bit is at register 0x2D bit 1. No bits in register 0x06 are required to be set. ### 8.3.8 INTERRUPT ON FIFO THRESHOLD (FIFO THRESH INT) The FIFO\_THRESH flag bit in register 0x0A bit 2 is active when the FIFO enable (FIFO\_EN) control is enabled in register 0x2D bit 5. The FIFO\_THRESH flag will be set to '0' following a POR or SW\_RESET because the default state of the FIFO is empty, and the default threshold level is a count of 16 samples (located in register 0x2E). Note that the FIFO\_THRESH bit may transition on any write or read to the FIFO when a threshold level is crossed. The FIFO\_THERESH\_INT\_EN interrupt control bit is at register 0x2D bit 2. No bits in register 0x06 are required to be set. ### 8.4 INTERRUPT SERVICING The MC3479 offers two methods for software to clear interrupts, and three operational modes. Methods: - Global Method: Software may globally clear all pending interrupts. - Bitmask/Individual Method: Software may individually clear specific interrupts. #### Modes: - Mode 1 Latched: software clears any/all pending interrupts. - Mode 2 Temp Latched: software clears interrupts or the temp\_latch timer feature in register 0x4A clears interrupts on a selected time out period. - Mode 3 Auto-Clear: software clears interrupts or hardware auto-clears interrupts. Note that some interrupts are not supported in Modes 2 or 3 (see Error! Reference source not found. and Error! Reference source not found. below). Please contact mCube for more information. ### 8.4.1 GLOBAL INTERRUPT SERVICE METHOD Global mode (register 0x31 bit 6 = 0) is the default means for servicing interrupts. In this mode any write to registers 0x04 or 0x14 will clear \*any\* pending interrupts, including the FIFO interrupts in register 0x2F. The contents of the write cycle to registers 0x04/0x14 is ignored, but the address is used to generate the clear pulse. The table below shows how the interrupt sources behave in the three modes of interrupt operations. **Note that the FIFO interrupts only operate in Mode 1.** ### 8.4.2 BITMASK/INDIVIDUAL INTERRUPT SERVICE MODE Bitmask/individual mode is enabled by setting register 0x31 bit 6 to '1'. In this mode, register 0x04 is not used to clear interrupts, only register 0x14. The contents of the write cycle to register 0x14 determine which interrupts are cleared (0 = no change, 1 = clear). Writing to register 0x14 bit 5 clears all pending FIFO interrupt flags in 0x2F (e.g. the single FIFO\_INTR bit at register 0x14 bit 5 is a combined FIFO interrupt clear). The table below shows how the interrupt sources behave in the three modes of interrupt operations. Note that the FIFO interrupts only operate in Mode 1. | Mode of<br>Operation | | ACQ_INT | TILT_35_INT | SHAKE_INT | ANYM_INT | FLIP_INT | TILT_INT | |----------------------|-------|-----------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------| | Mode 1<br>Latched | Set | End of Z-axis<br>processing | TILT_35 condition<br>has exceeded<br>TILT_35 duration<br>(1.6 to 3.0s).<br>ANYM enable<br>required. | SHAKE_INT peak<br>threshold and<br>duration have<br>been met. ANYM<br>enable required. | ANYM lock status<br>met and relative<br>threshold<br>exceeded. | TF threshold<br>exceeded and<br>debounce count<br>met for TILT to<br>FLIP transitions. | TF threshold exceeded and debounce count met for FLAT to TILT or FLIP to TILT transitions. | | | Clear | Write to 0x14 | Write to 0x14 | Write to 0x14 | Write to 0x14 | Write to 0x14 | Write to 0x14 | | Mode 2<br>Temp Latch | Set | End of Z-axis processing | TILT_35 condition<br>has exceeded<br>TILT_35 duration | SHAKE_INT peak<br>threshold and<br>duration have | ANYM lock status<br>met and relative | TF threshold<br>exceeded and<br>debounce count | TF threshold<br>exceeded and<br>debounce count | | | | | (1.6 to 3.0s).<br>ANYM enable<br>required. | been met. ANYM<br>enable required. | threshold<br>exceeded. | met for TILT to<br>FLIP transitions. | met for FLAT to<br>TILT or FLIP to TILT<br>transitions. | |----------------------|-------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------| | | Clear | Temp latch period<br>timeout or write to<br>0x14 | Temp latch period<br>timeout or write to<br>0x14 | Temp latch period<br>timeout or write to<br>0x14 | Temp latch period timeout or write to 0x14 | Temp latch period<br>timeout or write to<br>0x14 | Temp latch period<br>timeout or write to<br>0x14 | | Mode 3<br>Auto-Clear | Set | End of Z-axis<br>processing | TILT_35 condition<br>has exceeded<br>TILT_35 duration<br>(1.6 to 3.0s).<br>ANYM enable<br>required. | SHAKE_INT peak<br>threshold and<br>duration have<br>been met. ANYM<br>enable required. | ANYM lock status<br>met and relative<br>threshold<br>exceeded. | TF threshold<br>exceeded and<br>debounce count<br>met for TILT to<br>FLIP transitions. | TF threshold exceeded and debounce count met for FLAT to TILT or FLIP to TILT transitions. | | | Clear | Beginning of Z-axis<br>accumulation, or<br>write to 0x14 | Cleared when condition ends or is reset by hardware, or write to 0x14 | Cleared when condition ends or is reset by hardware, or write to 0x14 | Cleared when condition ends or is reset by hardware, or write to 0x14 | Cleared when<br>condition ends or<br>is reset by<br>hardware, or write<br>to 0x14 | Cleared when condition ends or is reset by hardware, or write to 0x14 | Table 14. Interrupt servicing details (Motion + Sample) | Mode of Operation | | FIFO_THRESH | FIFO_FULL | FIFO_EMPTY | |-------------------|-------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------| | Mode 1<br>Latched | Set | FIFO sample count equals or exceeds the FIFO threshold count in register 0x2E. | FIFO has 32 samples; hardware writes to the FIFO in WAKE mode and FIFO_EN = 1. | FIFO has 0 samples. Reading<br>the FIFO at register 0xD with<br>I2C/SPI removes 1 or more<br>samples. | | | Clear | Write to 0x14 | Write to 0x14 | Write to 0x14 | Table 15. Interrupt servicing details (FIFO) ### 8.5 INTERRUPT REQUESTS AND EXTERNAL INT PINS MC3479 has two pins which support external interrupts. Each pin may be separately configured as open-drain or active drive and the polarity is programmable. Note that the drive and polarity control has been moved from register 0x07 to register 0x33. By default the sample + motion interrupt request is routed to the INTN1 pin, and FIFO interrupt request is routed to the INTN2 pin. These requests may be swapped between the INTN1 pin and INTN2 pin or combined on a single pin. ### 8.5.1 SELECTING DRIVE AND POLARITY The drive mode (open-drain or push/pull) are controlled by register 0x33 bits 7:6 and 3:2. | A -1 -1- | Nama | Descriptio | | Bit | | | | | | | DOD Value | DAV | |----------|-----------|-----------------------------|---------------------|-------------------------|------|------|---------------------|-------------------------|------|------|-----------|-----| | Addr | Ir Name n | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | POR Value | R/W | | 0x33 | GPIO_CTRL | GPIO<br>Control<br>Register | GPIO2_<br>INTN2_IPP | GPIO2_<br>INTN2_<br>IAH | Resv | Resv | GPIO1_<br>INTN1_IPP | GPIO1_<br>INTN1_<br>IAH | Resv | Resv | 0x00 | RW | **Table 16. GPIO Control Register** | Bit | Name | Function | Description | |-----|-----------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | GPIO1_INTN1_IAH | Set polarity of INTN1 output. | O: The INTN1 pin is active low. 1: The INTN1 pin is active high. This bit sets the polarity level of the INTN1 pin. This bit is used in interrupt mode to set the level of the interrupt request. | | 3 | GPIO1_INTN1_IPP | Select open drain or push/pull mode for INTN1. | O: The INTN1 pin operates in open-drain mode as an output and requires an external pullup to VDD. 1: The INTN1 pin operates in push-pull mode as an output. This bit sets the drive mode of the INTN1 pin as an interrupt request output. | | 6 | GPIO2_INTN2_IAH | Set polarity of INTN2 output. | O: The INTN2 pin is active low. 1: The INTN2 pin is active high. This bit sets the polarity level of the INTN2 pin. This bit is used in interrupt mode to set the level of the interrupt request. | | 7 | GPIO2_INTN2_IPP | Select open drain or push/pull mode for INTN2. | O: The INTN2 pin operates in open-drain mode as an output and requires an external pullup to VDD. 1: The INTN2 pin operates in push-pull mode as an output. This bit sets the drive mode of the INTN2 pin as an interrupt request output. | Table 17. Interrupt drive and polarity control ### 8.5.2 SWAPPING INT PINS The interrupt requests driving the INTN1 and INTN2 pins may be swapped. Setting register 0x31 bit 4 to '1' (INT1\_INT2\_REQ\_SWAP) internally swaps the INT1\_REQ and INT2\_REQ signals in the MC3479. To clarify, the requests are swapped, but the bits controlling the INTN1 and INTN2 pin mode, drive, and polarity are not. | Bit | Name | Function | Description | |-----|--------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | INT1_INT2_REQ_SWAP | Swap INT1 and INT2 pin functionality. | O: INT1 requests are routed to the INTN1 pin, INTN2 requests are routed to the INT2 pin (default). 1: INT1 requests are routed to the INTN2 pin, INT2 requests are routed to the INTN1 pin | Table 18. Swapping Interrupt Requests, register 0x31 bit 4 ### 8.5.3 COMBINING INTERRUPT REQUESTS The separate internal interrupt requests (INT1\_REQ or motion + sample, and INT2\_REQ or FIFO) may be combined into a single request that appears on one pin. Setting register 0x2D bit 3 (COMB\_INT\_EN) to '1' combines both requests on INT1\_REQ that is routed to the INTN1 pin. To move it to the INTN2 pin, use the pin "swap" feature described in the previous section. | Bit | Name | Function | Description | |-----|-------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | COMB_INT_EN | Combined interrupt enable. | O: Motion/interrupt on sample interrupts are routed to INTN1, and FIFO interrupts are routed to INTN2. (default). 1: All interrupts are routed to INTN1. When the COMB_INT_EN bit is set, all interrupts requests are routed to INT1_REQ internally. INT2_REQ becomes disabled. | Table 19. Combining interrupt requests, register 0x2D bit 3 ### 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 output data rate. 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 status register for more information about ACQ\_INT. ### 9.2 SETTING THE SAMPLE RATE The MC3419 supports eight sample rates using I2C or SPI interfaces. When decimation mode is disabled, the table below shows the "internal data rate" (IDR) which is the same as ODR (ODR = IDR). The <u>sample rate register</u> (0x08) selects the WAKE mode sample rate. If the I2C interface is selected or if the SPI clock frequency is 4 MHz or less, use the register 0x08 settings as shown in the "Selection A" column below. If the SPI clock frequency is 4 MHz to 10 MHz, use the register 0x08 settings as shown in the "Selection B" column below. | | I2C o<br>I2C Speed<br>SPI Speed | | SPI Only<br>4MHz < SPI Speed ≤ 10MHz | | | |------|---------------------------------|------------------------------|--------------------------------------|------------------------------|--| | Rate | IDR = ODR (Hz) | Register 0x08<br>Selection A | IDR = ODR (Hz) | Register 0x08<br>Selection B | | | 0 | 25 | 0x10 | 50 | 0x08 | | | 1 | 50 | 0x11 | 62.5 | 0x09 | | | 2 | 62.5 | 0x12 | 100 | 0x0A | | | 3 | 100 | 0x13 | 125 | 0x0B | | | 4 | 125 | 0x14 | 250 | 0x0C | | | 5 | 250 | 0x15 | 500 | 0x0D | | | 6 | 500 | 0x16 | 1000 | 0x0E | | | 7 | 1000 | 0x17 | - | - | | **Table 20. Sample Rate Settings** ### 9.3 ADDITIONAL RATE OPTIONS The MC3479 is able to generate slower sample rates from the frequencies listed in The MC3419 supports eight sample rates using I2C or SPI interfaces. When decimation mode is disabled, the table below shows the "internal data rate" (IDR) which is the same as ODR (ODR = IDR). The sample rate register (0x08) selects the WAKE mode sample rate. If the I2C interface is selected or if the SPI clock frequency is 4 MHz or less, use the register 0x08 settings as shown in the "Selection A" column below. If the SPI clock frequency is 4 MHz to 10 MHz, use the register 0x08 settings as shown in the "Selection B" column below. | | I2C or SPI<br>I2C Speed ≤ 1MHz or<br>SPI Speed ≤ 4MHz | | SPI Only<br>4MHz < SPI Speed ≤ 10MHz | | |------|-------------------------------------------------------|------------------------------|--------------------------------------|------------------------------| | Rate | IDR = ODR (Hz) | Register 0x08<br>Selection A | IDR = ODR (Hz) | Register 0x08<br>Selection B | | 0 | 25 | 0x10 | 50 | 0x08 | | 1 | 50 | 0x11 | 62.5 | 0x09 | | 2 | 62.5 | 0x12 | 100 | 0x0A | | 3 | 100 | 0x13 | 125 | 0x0B | | 4 | 125 | 0x14 | 250 | 0x0C | | 5 | 250 | 0x15 | 500 | 0x0D | | 6 | 500 | 0x16 | 1000 | 0x0E | | 7 | 1000 | 0x17 | - | - | Table 20. When decimation mode is enabled the "internal data rate" (IDR) is divided by a fixed ratio to obtain an ODR or "output data rate". If decimation mode is not enabled (default), the IDR and ODR are the same frequency. The <u>FIFO control 2/sample rate 2 register</u> (0x30) selects the ratio used for decimation mode. | Bits | Name | Function | Description | |------|------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3:0 | DEC_MODE_<br>RATE[3:0] | Decimation mode rate selection. | 0000: Decimation mode disabled (default). 0001: Divide sample rate by 2 0010: Divide sample rate by 4 0011: Divide sample rate by 5 0100: Divide sample rate by 8 0101: Divide sample rate by 10 0110: Divide sample rate by 16 0111: Divide sample rate by 20 1000: Divide sample rate by 40 1001: Divide sample rate by 67 1010: Divide sample rate by 80 1011: Divide sample rate by 100 1100: Divide sample rate by 200 1101: Divide sample rate by 200 1101: Divide sample rate by 250 | ### MC3479 3-Axis Accelerometer | | 1110: Divide sample rate by 500 1111: Divide sample rate by 1000 When decimation mode is enabled, the internal data rate (IDR) is divided by the above factor to create a slower output data rate (ODR). The FIFO, motion block, output registers, and interrupts operate off the slower ODR when decimation mode is on. If decimation mode is disabled, then the IDR and ODR are the same value. | |--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| |--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| **Table 21. Hardware Decimation Ratios** The FIFO, motion events, and interrupts operate at the decimated rate (output data rate) when decimation mode is enabled. The low pass filter always operates at the internal data rate whether decimation mode is on or off. # 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 DOUT\_A6 pin during power-up as shown in the table below. 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 | DOUT_A6 level upon<br>power-up | |---------------------|-----------------------|----------------------|--------------------------------| | 0x4C<br>(0b1001100) | 0x98 | 0x99 | GND | | 0x6C<br>(0b1101100) | 0xD8 | 0xD9 | VDD | **Table 22. I2C Address Selection** The I2C interface remains active as long as power is applied to the VDD 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 mode register can be modified (see the Operational States 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 <u>I2C Timing Characteristics</u> 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<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. The second byte is the 8-bit register address of the device to access. The last byte is the data to write. Figure 13. 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 14. 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 I2C 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 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 <u>device status register</u> (0x05) clears the I2C\_WDT bit. #### 11 SPI INTERFACE #### 11.1 SPI PHYSICAL INTERFACE The device always operates as an SPI slave. An SPI master must initiate all communication and data transfers and generate the SCK\_SCL clock that synchronizes the data transfer. The CSN pin must be pulled up to VDD when the SPI interface is not in use. The SPI interface can operate in 3-wire or 4-wire mode. See section 9.2 for SPI clock selection and Output Data Rate, ODR. #### 11.2 SPI PROTOCOL An SPI write transaction requires a minimum of 16 clock cycles, and a SPI read transaction requires a minimum of 24 cycles of the SCK\_SCL pin. The falling edge of CSN initiates the start of the SPI bus cycle. When the SPI master is writing data to the MC3419 via the SPI DIN pin, data may change when the SCL\_SCK is low, and must be stable on the rising edge. Similarly, output data written from MC3419 to the SPI master is shifted out on the SPI DOUT pin on the falling edge of SCL\_SCK and can be latched by the master on the rising edge of SCL\_SCK. Serial data in or out of the device is always MSB first. #### 11.3 SPI REGISTER WRITE CYCLE - SINGLE A single register write consists of a 16-clock transaction. As described above, the first bit is set to '0' indicating a register write followed by the register address. Figure 15. SPI Register Write Cycle - Single #### 11.4 SPI REGISTER WRITE CYCLE - BURST A burst (multi-byte) register write cycle uses the address specified at the beginning of the transaction as the starting register address. Internally the address will auto-increment to the next consecutive address for each additional byte (8-clocks) of data written beyond clock 8. Figure 16.SPI Register Write Cycle - Burst (3-register burst example) #### 11.5 SPI REGISTER READ CYCLE - SINGLE A single register read consists of a 24-clock transaction. As described above, the first bit is set to '1' indicating a register read followed by the register address. Figure 17. SPI Register Read Cycle - Single #### 11.6 SPI REGISTER READ CYCLE - BURST A burst (multi-byte) register read cycle uses the address specified at the beginning of the transaction as the starting register address. Internally the address will auto-increment to the next consecutive address for each additional byte (8-clocks) of data read beyond clock 8. Figure 18. SPI Register Read Cycle - Burst (2 register burst example) ## 12 REGISTER INTERFACE The device has a register interface which allows an MCU, I2C or SPI 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. #### 12.1 REGISTER SUMMARY **NOTE:** Registers are not updated with new event status or samples while an I2C or SPI 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 - 0 | )x04 | | | | | RESERVI | ED <sup>2</sup> | | | | | • | | 0x05 | DEV_STAT | <u>Device Status</u><br><u>Register</u> | OTP_BUSY | SEC_ENA<br>(TMODE) | RESV | I2C_WDT | RESV | RES_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> | RESV | RESV | I2C_<br>WDT_POS | I2C_<br>WDT_NEG | RESV | 03 | STATE1 | STATE0 | 0x00 | W | | 0x08 | SR | Sample Rate | <b>0</b> <sup>3</sup> | <b>0</b> <sup>3</sup> | $0^{3}$ | $0^{3}$ | 03 | 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_<br>EN | MOTION_<br>LATCH | TF_<br>ENABLE | 0x00 | w | | 0x0A | FIFO_<br>STAT | <u>FIFO Status</u><br><u>Register</u> | RESV | RESV | RESV | RESV | RESV | THRESH | FIFO_FULL | FIFO_<br>EMPTY | 0x00 | RO | | 0x0B | FIFO-RD_P | FIFO Read Pointer | RESV | RESV | FIFO_<br>RD_PTR[5] | FIFO_<br>RD_PTR[4] | FIFO_<br>RD_PTR[3] | FIFO_<br>RD_PTR[2] | FIFO_<br>RD_PTR[1] | FIFO_<br>RD_PTR[0] | 0x00 | RO | | 0x0C | FIFO_<br>WR_P | FIFO Write Pointer | RESV | RESV | FIFO_<br>WR_PTR[5] | FIFO_<br>WR_PTR[4] | FIFO_<br>WR_PTR[3] | FIFO_<br>WR_PTR[2] | FIFO_<br>WR_PTR[1] | FIFO_<br>WR_PTR[0] | 0x00 | RO | | 0x0D | XOUT_<br>EX_L | XOUT Accelerometer 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 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 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 | | 0x13 | STATUS | Status Register | NEW_<br>DATA | RESV | FIFO_FLAG | TILT_35_<br>FLAG | SHAKE_<br>FLAG | ANYM_<br>FLAG | FLIP_FLAG | TILT_<br>FLAG | 0x00 | R | | 0x14 | INTR_<br>STAT | Interrupt Status<br>Register | ACQ_INT | RESV | FIFO_INT | TILT_35_<br>INT | SHAKE_<br>INT | ANYM_<br>INT | FLIP_INT | TILT_INT | 0x00 | R | | 0x15 - 0 | x1F | | | | | RESERVI | $ED^2$ | | | | | | | 0x20 | RANGE | Range Select Control | $0^{3}$ | RANGE[2] | RANGE[1] | RANGE[0] | LPF_EN | LPF[2] | LPF[1] | LPF[0] | 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 | | 10x24 | 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 | <u>Z-Offset</u><br><u>LSB</u> | ZOFF[7] | ZOFF[6] | ZOFF[5] | ZOFF[4] | ZOFF[3] | ZOFF[2] | ZOFF[1] | ZOFF[0] | Per chip | w | | 0x26 | ZOFFH | <u>Z-Offset</u><br><u>MSB</u> | 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 | Y Gain | YGAIN[7] | YGAIN[6] | YGAIN[5] | YGAIN[4] | YGAIN[3] | YGAIN[2] | YGAIN[1] | YGAIN[0] | Per chip | w | | 0x29 | ZGAIN | <u>Z Gain</u> | ZGAIN[7] | ZGAIN[6] | ZGAIN[5] | ZGAIN[4] | ZGAIN[3] | ZGAIN[2] | ZGAIN[1] | ZGAIN[0] | Per chip | w | | 0x2A | \ -0x2C | | | | | RESERVI | $ED^2$ | | | | | | | 0x2D | FIFO_<br>CTRL | FIFO Control Register | 03 | FIFO_<br>MODE | FIFO_EN | FIFO_RESET | COMB_INT<br>_ EN | FIFO_TH_<br>INT_EN | FIFO_FULL_<br>INT_EN | FIFO_<br>EMPTY_<br>INT_EN | 0x00 | w | | 0x2E | FIFO_TH | FIFO Threshold<br>Register | RESV | RESV | RESV | FIFO_TH[4] | FIFO_TH[3] | FIFO_TH[2] | FIFO_TH[1] | FIFO_TH[0] | 0x10 | w | | 0x2F | FIFO_<br>INTR | FIFO Interrupt Status<br>Register | 03 | RESV | RESV | RESV | RESV | FIFO_<br>THRESH_<br>INT (RO) | FIFO_FULL_<br>INT (RO) | FIFO_EMPT<br>Y _INT (RO) | 0x00 | R<br>W | | 0x30 | FIFO_<br>CTRL2 _SR2 | FIFO Control 2,<br>Sample Rate 2<br>Register | FIFO_<br>BURST_<br>MODE | 0 <sup>3</sup> | SELECT_<br>WRAP_<br>ADDR | ENABLE_<br>WRAP_N | DEC_MODE<br>RATE[3] | DEC_<br>MODE<br>RATE[2] | DEC_MODE<br>RATE[1] | DEC_MODE<br>RATE[0] | 0x00 | w | | 0x31 | COMM_<br>CTRL | Comm. Control<br>Register | 03 | INDIV_<br>INTR_CLR | SPI_3WIRE<br>_ EN | INT1_INT2_<br>REQ_SWAP | 03 | 03 | RESV | RESV | 0x00 | w | | 0: | x32 | | | | | RESERVI | $ED^2$ | | | | | | | 0x33 | GPIO_<br>CTRL | <u>GPIO</u><br><u>Control Register</u> | INTN2_<br>IPP | INTN2_IAH | RESV | RESV | INTN1_<br>IPP | INTN1_IAH | RESV | RESV | 0x00 | W | | 0x3 | 4 -0x3F | | | | L | RESERVI | ED <sup>2</sup> | | | | u . | | | 0x40 | TF_<br>THRESH_L<br>SB | Tilt/Flip Threshold 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_L<br>SB | 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 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_L<br>SB | 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 | #### MC3479 3-Axis Accelerometer | 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> | |-----------------------------------|-----------------------------------|----------------------------------------------------|-------------------------|--------------------|--------------------|--------------------|--------------------|--------------------|-------------------|-------------------|--------------|------------------| | 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_D<br>UR_<br>THRESH_L<br>SB | 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_D<br>UR_<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_CT<br>RL | 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 | | 0x4B | RD_CNT | Read Count Register | RD_CNT[7] | RD_CNT[6] | RD_CNT[5] | RD_CNT[4] | RD_CNT[3] | RD_CNT[2] | RD_CNT[1] | RD_CNT[0] | 0x06 | R/W | | 0x4C – 0x50 RESERVED <sup>2</sup> | | | | | | | | | | | | | <sup>1 &#</sup>x27;R' registers are read-only, via external I2C access. 'W' registers are read-write, via external I2C access. Registers designated as 'RESERVED' should not be accessed by software. Software must write a zero (0) to this bit. **Table 23. Register Summary** <sup>&</sup>lt;sup>4</sup> Software must write a one (1) to this bit. ## 12.2 (0X05) 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 | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | STATE[1:0] | <ul> <li>Operating mode of the current device.</li> <li>00: STANDBY. Clocks are not running and X, Y, and Z-axis data are not sampled.</li> <li>01: WAKE. Clocks are running and X, Y, and Z-axis data are acquired at the sample rate.</li> <li>10: Reserved.</li> <li>11: Reserved.</li> </ul> | | RES_MODE | Resolution mode of the current device. <b>0</b> : 16-bit (high) resolution is enabled. <b>1</b> : Reserved. | | I2C_WDT | <ul> <li>12C watchdog timeout. This bit is cleared when register 0x05 is read.</li> <li>0: A watchdog event is not detected.</li> <li>1: A watchdog event has been detected by the hardware and the I2C slave state machine is reset to idle.</li> </ul> | | OTP_BUSY | One-Time programming (OTP) activity status. 0: Internal memory is idle and the device is ready to use. 1: Internal memory is active and the device cannot be used. | **Table 24. Device Status Register** ## 12.3 (0X06) INTERRUPT ENABLE REGISTER The interrupt enable register enables or disables the reporting of interrupt status for each interrupt source. FIFO interrupt are enabled in the FIFO control register 0x2D. | 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 | 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 | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TILT_INT_EN | Use with the tilt/flip feature in the motion control register (register 0x09, bit 0) to activate the reporting status of the tilt interrupt. 0: Tilt interrupt is disabled. 1: Tilt interrupt is enabled. | | FLIP_INT_EN | Use with the tilt/flip feature in the motion control register (register 0x09, bit 0) to activate the reporting status of the flip interrupt. 0: Flip interrupt is disabled. 1: Flip interrupt is enabled. | | ANYM_INT_EN | Use with the AnyMotion feature in the motion control register (register 0x09, bit 2) to activate the reporting status of the AnyMotion interrupt. O: AnyMotion interrupt is disabled. 1: AnyMotion interrupt is enabled. | | SHAKE_INT_EN | 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 activate the reporting status of the shake interrupt. 0: Shake interrupt is disabled. 1: Shake interrupt is enabled. | | TILT_35_INT_EN | 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 activate the reporting status of the tilt-35 interrupt. 0: Tilt-35 interrupt is disabled. 1: Tilt-35 interrupt is enabled. | | AUTO_CLR_EN | Clear pending interrupts automatically or by reading a register. Enabling more than one interrupt timeout or service feature may produce unexpected results. O: Clear pending interrupts by writing to register 0x14. 1: Automatically clear pending interrupts if the interrupt condition is no longer valid. Refer to Interrupts for more information about interrupts. | | ACQ_INT_EN | <ul> <li>Generate interrupts.</li> <li>Disable automatic interrupt after each sample (default).</li> <li>Enable automatic interrupt after each sample (activates the ACQ_INT flag, bit 7, in register 0x14).</li> </ul> | Table 25. Interrupt Enable Register ## 12.4 (0X07) 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/<br>W | |----------------------|------------------------------------------|-------------|-------|-------|-----------------|-----------------|-------|-------|----------|----------|--------------|---------| | 0x07 | MODE | Mode | Resv | Resv | I2C_<br>WDT_POS | I2C_<br>WDT_NEG | 0 | 01 | STATE[1] | STATE[0] | 0x00 | w | | <sup>1</sup> Softwar | Software must write a zero (0) to bit 2. | | | | | | | | | | | | | Name | Description | |-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | STATE[1:0] | <ul> <li>Accelerometer operational state.</li> <li>00: STANDBY. Clocks are not running and X, Y, and Z-axis data are not sampled.</li> <li>01: WAKE. Clocks are running and X, Y, and Z-axis data are acquired at the sample rate.</li> <li>10: Reserved.</li> <li>11: Reserved.</li> </ul> | | I2C_WDT_NEG | Watchdog timer for negative SCL stalls. 0: The I2C watchdog timer for negative SCL stalls is disabled (default). 1: The I2C watchdog timer for negative SCL stalls is enabled. | | I2C_WDT_POS | Watchdog timer for positive SCL stalls. 0: The I2C watchdog timer for positive SCL stalls is disabled (default). 1: The I2C watchdog timer for positive SCL stalls is enabled. | **Table 26. Mode Register States** ## 12.5 (0X08) SAMPLE RATE REGISTER The sample rate register sets the sampling output data rate (ODR) for the sensor and the clock frequency of the main oscillator. | 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 | 01 | 01 | 01 | See tab | le below | RATE[2] | RATE[1] | RATE[0] | 0x00 | RW | <sup>&</sup>lt;sup>1</sup>Software must write a zero (0). | Name | Description | |-----------|----------------------------------| | RATE[2:0] | Select the Output Data Rate, ODR | **Table 27. Sample Rate Register** | | I2C or SPI Sp | eed ≤ 4MHz | I2C or 4MHz < SP | I Speed ≤ 10MHz | |------|----------------|------------|------------------|-----------------| | Rate | IDR = ODR (Hz) | Reg 0x08 | IDR = ODR (Hz) | Reg 0x08 | | 0 | 25 | 0x10 | 50 | 0x08 | | 1 | 50 | 0x11 | 62.5 | 0x09 | | 2 | 62.5 | 0x12 | 100 | 0x0A | | 3 | 100 | 0x13 | 125 | 0x0B | | 4 | 125 | 0x14 | 250 | 0x0C | | 5 | 250 | 0x15 | 500 | 0x0D | | 6 | 500 | 0x16 | 1000 | 0x0E | | 7 | 1000 | 0x17 | - | - | **Table 28. Sample Rate Values** ## 12.6 (0X09) 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/<br>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 | | | | | | | | | TE ENABLE | 0x13, 0x14, and 0x06. | | | | | | | | | TF_ENABLE | 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 | 0: 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. | | | | | | | | | | <b>0</b> : 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. | | | | | | | | | SHAKE _EN | <b>0</b> : 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. | | | | | | | | | 1121_33 _211 | <b>0</b> : Tilt-35 feature is disabled (default). | | | | | | | | | | 1: Tilt-35 feature is enabled. ANYM_EN must also be enabled. | | | | | | | | | | 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. | | | | | | | | | | 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). | | | | | | | | | 141011014_1(2521 | 1: The motion block is held in reset. The software must set this bit for the | | | | | | | | | | reset to be cleared. | | | | | | | | **Table 29. Motion Control Register** #### 12.7 (0X0A) FIFO STATUS 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 | |------|-----------|-------------|-------|-------|-------|-------|-------|-----------------|-----------|----------------|--------------|---------| | 0x0A | FIFO_STAT | FIFO Status | RESV | RESV | RESV | RESV | RESV | FIFO_<br>THRESH | FIFO_FULL | FIFO_<br>EMPTY | 0x01 | RO | This register returns the current flags/status from the FIFO. These signals are not registered so the bits may transition unexpectedly at any time. The FIFO interrupt enable bits in register 0x2D do not affect these flags. Note that the FIFO\_EMPTY flag is '1' at boot or POR. | Bit | Name | Description | |-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | FIFO_EMPTY | 0: FIFO is not empty 1: FIFO is empty (default) This flag is valid if the FIFO is enabled or disabled. | | 1 | FIFO_FULL | 0: FIFO is not full (default) 1: FIFO is full This flag is valid if the FIFO is enabled or disabled. | | 2 | FIFO_THRESH | 0: FIFO threshold is less than threshold setting (default) 1: FIFO threshold is at or greater than threshold setting. The default threshold level is 16 or ½ of the 32 sample FIFO capacity. | | 7:3 | RESV | Reserved, returns '00000' when read. | Table 19: FIFO Status, 0x0A Register #### 12.8 (0X0B) FIFO READ POINTER 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 | FIFO_R_P | FIFO Read Pointer | RESV | RESV | FIFO_<br>RD_PTR[5] | FIFO_<br>RD_PTR[4] | FIFO_<br>RD_PTR[3] | FIFO_<br>RD_PTR[2] | FIFO_<br>RD_PTR[1] | FIFO_<br>RD_PTR[0] | 0x00 | RO | #### **READ POINTER** The FIFO read pointer is a 6-bit value that points to the current address of the read port on the FIFO. The actual address is bits 4:0 since the FIFO is limited to 32 locations. Bit 5 is used as "wrap" flag by hardware when comparing the read and write pointer. | Bit | Name | Description | |-----|------------------|---------------------------------------------------------------------------------------------------------------------------| | 4:0 | FIFO_RD_PTR[4:0] | 00000 – default This is the current address the FIFO read pointer is accessing. The valid range is 0 to 31. | | 5 | FIFO_RD_PTR[5] | 0 -default This bit is used by hardware to manage the full/empty status of the FIFO. This is not a physical address bit. | | 7:6 | RESV | Reserved, returns '00' when read. | Table 12-30: FIFO read pointer, register 0x0B ## 12.9 (0X0C) FIFO WRITE POINTER 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 | |------|----------|--------------------|-------|-------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------|---------| | 0x0C | FIFO_W_P | FIFO Write Pointer | RESV | RESV | FIFO_<br>WR_PTR[5] | FIFO_<br>WR_PTR[4] | FIFO_<br>WR_PTR[3] | FIFO_<br>WR_PTR[2] | FIFO_<br>WR_PTR[1] | FIFO_<br>WR_PTR[0] | 0x00 | RO | The FIFO write pointer is a 6-bit value that points to the current address of the write port on the FIFO. The actual address is bits 4:0 since the FIFO is limited to 32 locations. Bit 5 is used as "wrap" flag by hardware when comparing the read and write pointers. This value will always be updated when a new valid sample is acquired (Z-axis data must be successfully acquired). | Bit | Name | Description | |-----|------------------|---------------------------------------------------------------------------------------------------------------------------| | 4:0 | FIFO_WR_PTR[4:0] | 00000 – default This is the current address the FIFO write pointer is accessing. The valid range is 0 to 31. | | 5 | FIFO_WR_PTR[5] | O -default This bit is used by hardware to manage the full/empty status of the FIFO. This is not a physical address bit. | | 7:6 | RESV | Reserved, returns '00' when read. | Table 12-31: FIFO write pointer, register 0xC # 12.10 (0X0D - 0X12) XOUT, YOUT AND ZOUT DATA ACCELEROMETER REGISTERS X, Y, and Z-axis accelerometer measurements are in 16-bit, signed 2's complement format. Register addresses 0x0D to 0x12 hold the latest sampled data from the X, Y, and Z accelerometers. When the FIFO is enabled (register 0x2D bit 5), reading from address 0x0D supplies data from the FIFO instead of the output registers. # During FIFO reads, software must start a read at address 0x0D and complete a read to address 0x12 for the FIFO pointers to increment correctly. Once an I2C start bit has been recognized by the device, registers will not be updated until an I2C stop bit has occurred. Therefore, if software desires to read the low and high byte registers 'atomically', knowing that the values have not been changed, it should do so by issuing a start bit, reading one register, then reading the other register then issuing a stop bit. Note that all 6 registers may be read in one burst with the same effect. | 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 32. Accelerometer LSB and MSB Registers ## 12.11 (0X13) 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 | Status Register | NEW_<br>DATA | Resv | FIFO_FLA<br>G | 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 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. 0: 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. | | FIFO_FLAG | This flag is an OR of the three FIFO flags from register 0x0A, FIFO_FULL, FIFO_THRESH, and FIFO_EMPTY. | | 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 33. Status Register ## 12.12 (0X14) 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 written (default). Individual interrupts may be cleared using a bitmask if the INDIV\_INTR\_CLR bit is set in the communications control register, address 0x31. | Ī | 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 | |---|------|---------------|------------------------------|---------|-------|----------|-----------------|---------------|--------------|----------|----------|--------------|---------| | | 0x14 | INTR_<br>STAT | Interrupt Status<br>Register | ACQ_INT | Resv | FIFO_INT | TILT_35_<br>INT | SHAKE_<br>INT | ANYM_<br>INT | FLIP_INT | TILT_INT | 0x00 | RW | | 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. <b>0</b> : Tilt interrupt is not pending. <b>1</b> : Tilt interrupt is pending. | | 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. <b>0</b> : Flip interrupt is not pending. <b>1</b> : Flip interrupt is pending. | | 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. <b>0</b> : Shake interrupt is not pending. <b>1</b> : 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. O: Tilt-35 interrupt is not pending. 1: Tilt-35 interrupt is pending. | | FIFO_INT | 0: FIFO_INTR interrupt is not pending. 1: FIFO_INTR interrupt is pending. This bit is an OR of the three FIFO interrupt flags from register 0x2F, | | ACQ_INT | FIFO_FULL_INTR, FIFO_THRESH_INTR, and FIFO_EMPTY_INTR. 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 34. Interrupt Status Register** ## 12.13 (0X20) 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/<br>W | |-------------------------------------------------------|-------|-------------------------|-------|----------|----------|----------|--------|--------|--------|--------|--------------|---------| | 0x20 | RANGE | Range Select<br>Control | 01 | RANGE[2] | RANGE[1] | RANGE[0] | LPF_EN | LPF[2] | LPF[1] | LPF[0] | 0x00 | w | | <sup>1</sup> Software must write a zero (0) to bit 7. | | | | | | | | | | | | | | Name | Description | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RANGE[2:0] | Resolution range of the accelerometer, based on the current resolution. 000: ±2g 001: ±4g 010: ±8g 011: ±16g 100: ±12g 101: Reserved. 110: Reserved. 111: Reserved. | | LPF_EN | 0: Low pass Filter Disabled 1: Low Pass Filter Enabled | | LPF[2:0] | 000: Reserved 001: Bandwidth setting 1, Fc = IDR / 4.255 010: Bandwidth setting 2, Fc = IDR / 6 011: Bandwidth setting 3, Fc = IDR / 12 100: Reserved 101: Bandwidth setting 5, Fc = IDR / 16 110: Reserved 111: Reserved | Table 35. Range and Scale Control Register #### 12.14 (0X21 - 0X22) 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/<br>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 36. X-Axis Digital Offset Registers #### 12.15 (0X23 - 0X24) 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/<br>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 37. Y-Axis Digital Offset Registers #### 12.16 (0X25 - 0X26) 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 <u>Z-Axis Digital Gain Registers</u> 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/<br>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 38. Z-Axis Digital Offset Registers #### 12.17 (0X22 & 0X27) 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/<br>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 39. X-Axis Digital Gain Registers #### 12.18 (0X24 & 0X28) 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/<br>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 40. Y-Axis Digital Offset Registers** #### 12.19 (0X26 & 0X29) 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/<br>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 41. Z-Axis Digital Offset Registers** ## 12.20 (0X2D) FIFO CONTROL REGISTER This register controls the options for the MC3479 FIFO. This register was previously undefined in Mensa. | A | ddr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/<br>W | |----|-----|-----------|--------------------------|-------|---------------|---------|------------|-----------------|--------------------|----------------------|---------------------------|--------------|---------| | 0> | k2D | FIFO_CTRL | FIFO Control<br>Register | 0 | FIFO_<br>MODE | FIFO_EN | FIFO_RESET | COMB_INT<br>_EN | FIFO_TH_<br>INT_EN | FIFO_FULL_<br>INT_EN | FIFO_<br>EMPTY_<br>INT_EN | 0x00 | RW | | Bit | Name | Function | Description | |-----|-------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | FIFO_EMPTY_INT_EN | FIFO empty<br>interrupt<br>enable | 0: FIFO empty interrupt enable is disabled (default) 1: FIFO empty interrupt enable is enabled. | | 1 | FIFO_FULL_INT_EN | FIFO full<br>interrupt<br>enable | 0: FIFO full interrupt enable is disabled (default) 1: FIFO full interrupt enable is enabled. | | 2 | FIFO_TH_INT_EN | FIFO threshold interrupt enable. | 0: FIFO threshold interrupt enable is disabled (default) 1: FIFO full threshold enable is enabled. | | 3 | COMB_INT_EN | Combined<br>interrupt<br>enable | O: Motion/interrupt on sample interrupts are routed to INTN1, and FIFO interrupts are routed to INTN2. (default). 1: All interrupts are routed to INTN1. When the COMB_INT_EN bit is set, all interrupts requests are routed to INTN1, INTN2 becomes disabled. | | 4 | FIFO_RESET | FIFO reset<br>control | 0: FIFO is not reset (default) 1: FIFO is reset, read and write pointers are cleared. In a FIFO reset, <b>the contents of the FIFO are not cleared,</b> only the FIFO control logic, read and write pointers are reset. | | 5 | FIFO_EN | FIFO enable | 0: FIFO and FIFO operations are disabled (default) 1: FIFO and FIFO operations are enabled. | ## MC3479 3-Axis Accelerometer | 6 | FIFO_MODE | FIFO mode<br>select | O: Normal operation, the FIFO continues to accept new sample data as long as there is space remaining (default) 1: Watermark (threshold) mode, once the amount of samples in the FIFO reaches or exceeds the threshold level, the FIFO stops accepting new sample data. Any additional sample data is "dropped". | |---|-----------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Reserved | Reserved | This bit must be '0' for current FIFO operation. | Table 42. FIFO Control bit assignments ## 12.21 (0X2E) FIFO THRESHOLD REGISTER | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-----------|----------------------------|-------|-------|-------|------------|------------|------------|------------|------------|--------------|-----| | 0x2E | FIFO_CTRL | FIFO Threshold<br>Register | RESV | RESV | RESV | FIFO_TH[4] | FIFO_TH[3] | FIFO_TH[2] | FIFO_TH[1] | FIFO_TH[0] | 0x10 | RW | #### FIFO THRESHOLD SETTING Register 0x2E holds the threshold or "watermark" level to apply to the number of samples in the FIFO. Note that the POR default of the level is 0x10 (decimal 16), or ½ of the total size of the FIFO. | Bit | Name | Description | |-----|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 4:0 | FIFO_TH[4:0] | The FIFO threshold level selects the number of samples in the FIFO for different FIFO events. The threshold value may be 1 to 31 (00001 to 11111). | | 7:5 | RESV | Reserved, returns '0' when read. | Table 43. FIFO Threshold level bit assignments ## 12.22 (0X2F) FIFO INTERRUPT STATUS REGISTER | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|---------------|-----------------------------------|-------|-------|-------|-------|-------|------------------------------|-------|-------------------------|------------------|-----| | 0x2E | FIFO_<br>INTR | FIFO Interrupt<br>Status Register | RESV | RESV | RESV | RESV | RESV | FIFO_<br>THRESH_<br>INT (RO) | | FIFO_EMPT<br>Y_INT (RO) | 1 ()\(\gamma()() | R | Register 0x2F reports the status of any pending FIFO interrupts. The corresponding FIFO interrupt enable bit must be enabled in register 0x2D for the interrupts to be detected. | Bit | Name | Function | Description | |-----|--------------------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | FIFO_EMPTY_INT (RO) | FIFO Empty interrupt flag. | O: No FIFO empty interrupt is pending. 1: FIFO empty interrupt is pending. This read only bit reports the status of the FIFO empty interrupt. It requires register 0x2B bit 0 be enabled. | | 1 | FIFO_FULL_<br>INT (RO) | FIFO Full interrupt flag. | 0: No FIFO full interrupt is pending. 1: FIFO full interrupt is pending. This read only bit reports the status of the FIFO full interrupt. It requires register 0x2B bit 1 be enabled. | | 2 | FIFO_ FIFO Threshold interrupt flag. | | O: No FIFO threshold interrupt is pending. 1: FIFO threshold interrupt is pending. This read only bit reports the status of the FIFO threshold interrupt. It requires register 0x2B bit 2 be enabled. | | 7:3 | RESV (RO) | Reserved | Reserved bits, returns '00000' when read. | Table 44. Interrupt status bit assignments #### 12.23 (0X30) FIFO CONTROL REGISTER2, SAMPLE RATE REGISTER 2 This register controls the behavior of the FIFO burst mode, and the hardware decimation feature of the MC3479. The hardware decimation feature divides the internal data rate (IDR) generated by the timebase module. Blocks at the end of signal acquisition pipeline may run at a slower output data rate (ODR). The FIFO, motion, and interrupt blocks operate at the decimated rate while the ADC and LPF filter operate at the higher internal rate. The hardware decimation feature is disabled by default and can be applied to any data rate generated by the settings in register 0x08. FIFO burst mode refers to the reading of multiple samples from the FIFO in the same transaction. FIFO\_BURST must be set to '1' any time SW intends to drain more than one sample in the same read cycle. It is not necessary to use FIFO\_BURST mode for reading only one sample at a time (single 6, 7, or 8-byte sequence). | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|--------------------|----------------------------------------------------------|-------------------------|-------|--------------------------|-------------------|---------------------|---------------------|---------------------|---------------------|--------------|-----| | 0x30 | FIFO_CTRL<br>2_SR2 | FIFO Control<br>Register 2,<br>Sample Rate 2<br>Register | FIFO_<br>BURST_<br>MODE | 0 | SELECT_<br>WRAP_ADD<br>R | ENABLE_<br>WRAP_N | DEC_MODE<br>RATE[3] | DEC_MODE<br>RATE[2] | DEC_MODE<br>RATE[1] | DEC_MODE<br>RATE[0] | 00000000 | RW | | Bit | | | Description | |-----|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------| | 3:0 | DEC_MODE_<br>RATE[3:0] Decimation mode rate selection. | 0000: Decimation mode disabled (default). 0001: Divide sample rate by 2 0010: Divide sample rate by 4 0011: Divide sample rate by 5 0100: Divide sample rate by 8 0101: Divide sample rate by 10 0110: Divide sample rate by 16 0111: Divide sample rate by 20 1000: Divide sample rate by 40 1001: Divide sample rate by 40 1001: Divide sample rate by 80 1011: Divide sample rate by 80 1011: Divide sample rate by 100 1100: Divide sample rate by 200 1101: Divide sample rate by 250 1110: Divide sample rate by 500 1111: Divide sample rate by 1000 When decimation mode is enabled, the internal data rate (IDR) is divided by the above factor to create a slower output data rate (ODR). The FIFO, motion block, output registers, and interrupts operate off the slower ODR when decimation mode is disabled, then the IDR and ODR are the same value. | | | 4 | ENABLE_WRAP_N | Enable/disable automatic address increment to | 0: Internal register address pointer will "wrap" at address selected by bit 5 (default). | ## MC3479 3-Axis Accelerometer | | | internal register file.<br>Applies to I2C and SPI<br>operations. | 1: Internal register address pointer will increment to the next consecutive value. | |---|----------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | SELECT_WRAP_<br>ADDR | Select the register address<br>"wrap" value during burst<br>operations. | 0: Internal register address wraps from address 0x12 to 0x0D on read cycles. (default). 1: Internal register address wraps from address 0x14 to 0x0D on read cycles. This bit determines which register address triggers a "wrap" to register 0x0D (XOUT_LSB) during a read cycle. Address 0x12 is the MSB of the Z-axis data, and address 0x14 is the address of the interrupt data register. Setting this bit to a '1' allows the contents of 0x13 (accel flag bits) and 0x14 (accel interrupt flags) to be included in a read cycle that includes XOUT[15:0], YOUT[15:0], ZOUT[15:0], STATUS[7:0], and INTR_STATUS[7:0]. | | 6 | Reserved | Reserved. | This bit must be '0' for correct FIFO operation. | | 7 | FIFO_BURST | Enable FIFO burst read operations. | O: FIFO read cycle reads a single 6 byte XYZ sample from the FIFO (default). 1: FIFO read cycle reads 2 or more 6-byte XYZ samples (up to 32) from the FIFO. The length of the burst read must be set in the Read Count register, 0x4B. | Table 45. FIFO Control 2 bit assignments ## 12.24 (0X31) COMMUNICATION CONTROL REGISTER | Addı | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|-----------|---------------------------|-------|--------------------|-------|------------------------|-------|-------|-------|-------|--------------|-----| | 0x31 | COMM_CTRL | Comm. Control<br>Register | Resv | INDIV_<br>INTR_CLR | | INT1_INT2_<br>REQ_SWAP | 0 | 0 | RESV | RESV | 0x00 | RW | | Bit | Name | Function | Description | |-----|---------------------------------------------------------------------------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | RESV | Reserved | Reserved, returns '0' when read. | | 1 | RESV | Reserved | Reserved, returns '0' when read. | | 2 | RESV | Reserved | Reserved, this bit must be written to '0' by software. | | 3 | RESV | Reserved | Reserved, this bit must be written to '0' by software. | | 4 | INT1_INT2_REQ_S<br>WAP | Swap INT1 and INT2 pin functionality. | O: INT1 requests are routed to the INTN1 pin, INT2 requests are routed to the INTN2 pin (default). 1: INT1 requests are routed to the INTN2 pin, INT2 requests are routed to the INTN1 pin. | | 5 | SPI_3WIRE_EN | Enable SPI 3-wire mode. | 0: SPI 3-wire more is disabled (default). 1: SPI 3-wire mode is enabled When this bit is enabled, the DOUT_A6 pin becomes a bi-directional data pin. SPI MISO and MOSI is applied to the DOUT_A6 pin. Note that it is possible to simply tie the DIN_SDA and DOUT_A6 pins together to enable 3-wire mode without using this bit. | | 6 | SPI_3WIRE_EN Enable SPI 3-wire mode. INDIV_INTR_CLR Enable individual interrupt mode | | O: Individual interrupt clear mode is disabled. All interrupts are cleared by writing to register 0x14, contents of write cycle do not matter. (default). 1: Individual interrupt clear mode is enabled. Individual interrupts are cleared by writing to register 0x14 as a bitmask. Each bit of register 0x14 controls a corresponding interrupt service/clear bit. | | 7 | Reserved | Reserved | This bit must be '0' for proper device operation. | **Table 46. Communication Control bit assignments** ## 12.25 (0X33) GPIO CONTROL REGISTER This register is used to select the INTN1 pin and INTN2 pin polarity and drive mode when the pins are used as interrupt request outputs. | Addr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |------|---------------|--------------------------|---------------|-----------|-------|-------|---------------|-----------|-------|-------|--------------|-----| | 0x33 | GPIO_<br>CTRL | GPIO Control<br>Register | INTN2_<br>IPP | INTN2_IAH | RESV | RESV | INTN1_<br>IPP | INTN1_IAH | RESV | RESV | 0x00 | w | | Bit | Name | Function | Description | | | | | |-----|-----------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 1:0 | Reserved | Reserved | Reserved | | | | | | 2 | GPIO1_INTN1_IAH | | O: The INTN1 pin is active low. 1: The INTN1 pin is active high. This bit sets the polarity level of the INTN1 pin. This bit is used in interrupt mode to set the level of the interrupt request. | | | | | | 3 | GPIO1_INTN1_IPP | | O: The INTN1 pin operates in open-drain mode as an output. 1: The INTN1 pin operates in push-pull mode as an output. This bit sets the drive mode of the INTN1 pin as an interrupt request output. Open drain mode requires an external pullup resistor. | | | | | | 5:4 | Reserved | Reserved | Reserved | | | | | | 6 | GPIO2_INTN2_IAH | Set polarity of INTN2 output. | O: The INTN2 pin is active low. 1: The INTN2 pin is active high. This bit sets the polarity level of the INTN2 pin. This bit is used in interrupt mode to set the level of the interrupt request, or in GPIO mode to set the level of the GPIO output drive. | | | | | | 7 | GPIO2_INTN2_IPP | • • • • | O: The INTN2 pin operates in open-drain mode as an output. 1: The INTN2 pin operates in push-pull mode as an output. This bit sets the drive mode of the INTN2 pin as an interrupt request output. Open drain mode requires an external pullup resistor. | | | | | **Table 47. GPIO Control Register** #### 12.26 (0X40 - 0X41) 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/<br>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 48. Tilt/Flip Threshold Registers #### 12.27 (0X42) 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/<br>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 49. Tilt/Flip Debounce Register #### 12.28 (0X43 - 0X44) 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/<br>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 50. AnyMotion Threshold Registers #### 12.29 (0X45) 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/<br>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 | Table 51. AnyMotion Debounce Register ## 12.30 (0X46 - 0X47) 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/<br>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 52. Shake Threshold Registers #### 12.31 (0X48 - 0X49) 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/<br>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 53. Shake Duration and Peak-to-Peak Registers ## 12.32 (0X4A) 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 | . , | | | 1: The temporary latch feature is enabled. | **Table 54. Timer Control Register** ## 12.33 (0X4B) READ COUNT REGISTER The read count register (0x4B) sets length of FIFO burst read transactions. | Ac | ddr | Name | Description | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | POR<br>Value | R/W | |----|-----|--------|-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--------------|-----| | 0x | (4B | RD_CNT | Read Count | RD_CNT[7] | RD_CNT[6] | RD_CNT[5] | RD_CNT[4] | RD_CNT[3] | RD_CNT[2] | RD_CNT[1] | RD_CNT[0] | 0x06 | RW | | Bit | Name | Function | Description | |-----|-------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:0 | RD_CNT[7:0] | Sample count to be used during I2C/SPI read cycles. | Ox06: POR value (default) If register 0x30 bit 7 (FIFO_BURST) is enabled, this register is the number of samples to be read in single burst read transaction. A sample is one 6-byte sample from the FIFO and optionally one or two status bytes from registers 0x13 and 0x14 (a sample can be 6, 7, or 8-bytes long). Note this parameter is a sample count, not a byte count. If FIFO burst mode is disabled, this parameter is not used. | Table 55. Read Count Register ## 13 INDEX OF TABLES | Table 1. Order Information | 5 | |-------------------------------------------------------------|------------| | Table 2. Package Information | 5 | | Table 3. Pin Description | g | | Table 4. Absolute Maximum Ratings | 16 | | Table 5. Sensor Characteristics | 17 | | Table 6. Electrical Characteristics | 18 | | Table 7. Electrical and Timing Characteristics - Interface | 19 | | Table 8. I2C Timing Characteristics | 20 | | Table 9. SPI Interface Timing Parameters | 21 | | Table 10. Summary of Resolution, Range, and Scaling | 22 | | Table 11. Operational States | <b>2</b> 3 | | Table 12. Forcing Operational States | 24 | | Table 13. Interrupt Overview | 25 | | Table 14. Interrupt servicing details (Motion + Sample) | 29 | | Table 15. Interrupt servicing details (FIFO) | 29 | | Table 16. GPIO Control Register | 30 | | Table 17. Interrupt drive and polarity control | 30 | | Table 18. Swapping Interrupt Requests, register 0x31 bit 4 | 31 | | Table 19. Combining interrupt requests, register 0x2D bit 3 | 31 | | Table 20. Sample Rate Settings | 32 | | Table 21. Hardware Decimation Ratios | 34 | | Table 22. I2C Address Selection | 35 | | Table 23. Register Summary | 42 | | Table 24. Device Status Register | 43 | | Table 25. Interrupt Enable Register | 44 | | Table 26. Mode Register States | 45 | | Table 27. Sample Rate Register | 46 | | Table 28. Sample Rate Values | 46 | | Table 29. Motion Control Register | 47 | | Table 12-30: FIFO read pointer, register 0x0B | 49 | | Table 12-31: FIFO write pointer, register 0xC | 50 | | Table 32. Accelerometer LSB and MSB Registers | 51 | | | | ## MC3479 3-Axis Accelerometer | Table 33. Status Register | 52 | |-----------------------------------------------------|----| | Table 34. Interrupt Status Register | 54 | | Table 35. Range and Scale Control Register | 55 | | Table 36. X-Axis Digital Offset Registers | 56 | | Table 37. Y-Axis Digital Offset Registers | 57 | | Table 38. Z-Axis Digital Offset Registers | 58 | | Table 39. X-Axis Digital Gain Registers | 59 | | Table 40. Y-Axis Digital Offset Registers | 60 | | Table 41. Z-Axis Digital Offset Registers | 61 | | Table 42. FIFO Control bit assignments | 63 | | Table 43. FIFO Threshold level bit assignments | 64 | | Table 44. Interrupt status bit assignments | 65 | | Table 45. FIFO Control 2 bit assignments | 67 | | Table 46. Communication Control bit assignments | 68 | | Table 47. GPIO Control Register | 69 | | Table 48. Tilt/Flip Threshold Registers | 70 | | Table 49. Tilt/Flip Debounce Register | 71 | | Table 50. AnyMotion Threshold Registers | 72 | | Table 51. AnyMotion Debounce Register | 73 | | Table 52. Shake Threshold Registers | 74 | | Table 53. Shake Duration and Peak-to-Peak Registers | 75 | | Table 54. Timer Control Register | 76 | | Table 55 Read Count Register | 77 | # 14 REVISION HISTORY | Date | Revision | Description | |---------|-------------------|-------------------------------| | 2019-05 | APS-048-0072v1.0 | Initial release | | 2019-06 | APS-048-0072v1.01 | Fixed a few formatting issues | #### 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. 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. 2019. All rights reserved. 81 / 81 # **Mouser Electronics** **Authorized Distributor** Click to View Pricing, Inventory, Delivery & Lifecycle Information: mCube: