# The QMA6981 is a single chip three-axis accelerometer. This surface-mount, small sized chip has an integrated acceleration transducer with signal conditioning ASIC, sensing tilt, motion, shock and vibration. It is targeted for applications such as screen rotation, step counting, sleep quality, gaming and personal navigation in mobile and wearable smart devices. The QMA6981 is based on our state-of-the-art, high resolution single crystal silicon MEMS technology. Along with custom-designed 10-bit ADC ASIC, it offers the advantages of low noise, high accuracy, low power consumption, and offset trimming. The I<sup>2</sup>C serial bus allows for easy interface. The QMA6981 is in a 2mmx2mmx0.95mm surface mount 12-pin land grid array (LGA) package. #### **FEABS** 3-Axis Accelerometer in a 2x2x0.95 mm<sup>3</sup> Land Grid Array Package (LGA), guaranteed to operate over a temperature range of -40 °C to +85 °C. 10-Bit ADC with low noise accelerometer sensor I<sup>2</sup>C Interface with Standard and Fast modes. **Built-In Self-Test** Wide range operation voltage (2.4V To 3.6V) and low power consumption (27-50 PA low power conversion current) Integrated FIFO with a depth of 32 frames RoHS compliant, halogen-free Built-in motion algorithm ### **BENEFIT** Small size for highly integrated products. Signals have been digitized and factory trimmed. High resolution allows for motion and tilt sensing High-Speed Interfaces for fast data communications. Enables low-cost functionality test after assembly in production Automatically maintains sensor's sensitivity under wide operation voltage range and compatible with battery powered applications High Data-Read rate Environmental protection and wide applications Low power and easy applications including step counting, sleep quality, gaming and personal navigation Rev: C # CONENS | CO | NTENTS | | 2 | |----|---------------------|----------------------------------------------------------------|----| | 1 | INTER | NAL SCHEMATIC DIAGRAM | 3 | | | 1.1 | Internal Schematic Diagram | 3 | | 2 | SPECII | FICATIONS AND I/O CHARACTERISTICS | 4 | | | 2.1 | Product Specifications | 4 | | | 2.2 | Absolute Maximum Ratings | | | | 2.3 | I/O Characteristics | | | 3 | PACK | AGE PIN CONFIGURATIONS | | | | 3.1 | Package 3-D View | | | | 3.2 | Package Outlines | | | 4 | EXTER | RNAL CONNECTION | | | | 4.1 | Dual Supply Connection | | | | 4.2 | Single Supply connection | | | 5 | BASIC | DEVICE OPERATION | 10 | | | 5.1 | Acceleration Sensors | 10 | | | 5.2 | Power Management | 10 | | | 5.3 | Power On/Off Time | | | | 5.4 | Communication Bus Interface I <sup>2</sup> C and Its Addresses | 11 | | 6 | MODE | S OF OPERATION | 12 | | | 6.1 | Modes Transition | 12 | | | 6.2 | Description of Modes | 13 | | 7 | Function | ons and interrupts | 14 | | | 7.1 | POL_INT | 14 | | | 7.2 | FOB_INT | 14 | | | 7.3 | STEP/STEP_QUIT INT | 15 | | | 7.4 | TAP_INT | 16 | | | 7.5 | LOW-G_INT | | | | 7.6 | HIGH-G_INT | 18 | | | 7.7 | DRDY_INT | 18 | | | 7.8 | FIFO_INT | 19 | | | 7.9 | Interrupt configuration | | | 8 | I <sup>2</sup> C CO | MMUNICATION PROTOCOL | | | | 8.1 | I <sup>2</sup> C Timings | | | | 8.2 | I <sup>2</sup> C R/W Operation | | | 9 | REGIS | TERS | | | | 9.1 | Register Map | | | | 9.2 | Register Definition | 25 | # 1 INERAL SHEMATC DIAGRAM # 1.1 l**##30**ign | مهر | QMA6981<br>Datasheet | Rev: C | |-----|----------------------|--------| |-----|----------------------|--------| # 2 BECIFICATIONS AND I/O CHARCERECS # 2.1 Pts # 12. 6 \* 14425C 18.0 \( \text{D} \) (144) | Pten | CH | Min | Þ | Ma | b | |------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----|-----------|-----|-----------------| | Supply voltage VDD | VDD, for internal blocks | 2.4 | 3.3 | 3.6 | V | | I/O voltage VDDIO | | | | VDD | V | | Standby current | VDD and VDDIO on | | 2 | | μA | | Low power current | BW=500 Hz, ODR=1 Hz | | 27 | | μA | | Low power current | BW=500 Hz, ODR=10 Hz | | 29 | | μA | | Low power current | BW=500 Hz, ODR=20 Hz | | 31 | | μA | | Low power current | BW=500 Hz, ODR=40 Hz | | 37 | | μA | | Low power current | BW=500 Hz, ODR=100 Hz | | 50 | | μA | | Full run current | All blocks on, device in run state | | 220 | 300 | μA | | Sleep current | For analog, AFE is off, BG, Transducer<br>and oscillator are on or in low power<br>mode<br>For digital, only counter and FSM are<br>on | | 55 | | μА | | Deep sleep current | For analog, only BG and oscillator are on For digital, only counter and FSM are on | | 26 | | μΑ | | BW | Programmable bandwidth | | 3.9~500 | | Hz | | Data output rate (ODR) | 4*BW (ODRH=1) | | 15.6~2000 | | Samples<br>/sec | | Conversion time | in full speed | | 1/(4*BW) | | ms | Rev: C | Pten | CH | Min | <b>J</b> | Ma | b | |-------------|----|-----|----------|----|----| | Cross Axis | | | 4 | | 0/ | | Sensitivity | | | I | | % | Rev: C Fig2. Pigw ### 15. PiCts | PIN | PIN | I/O | Pev | <b>P</b> E | Fb | |-----|-------|-----|-------|------------|-----------------------------------| | No | NAME | | ß | | | | 1 | AD0 | | VDDIO | CMOS | LSB of I <sup>2</sup> C address | | 2 | SDA | 10 | VDDIO | CMOS | Serial data for I <sup>2</sup> C | | 3 | VDDIO | | VDDIO | Power | Power supply to digital interface | | 4 | RESV0 | 1 | VDDIO | CMOS | Reserved. Float or connect to GND | | 5 | INT1 | 0 | VDDIO | CMOS | Interrupt 1 | | 6 | INT2 | 0 | VDDIO | CMOS | Interrupt 2 | | 7 | VDD | | VDD | Power | Power supply to internal block | | 8 | GNDIO | | GND | Power | Ground to digital interface | | 9 | GND | | GND | Power | Ground to internal block | | 10 | RESV1 | 10 | VDDIO | CMOS | Reserved | | 11 | RESV2 | 10 | VDDIO | CMOS | Reserved | | 12 | SCL | 1 | VDDIO | CMOS | Serial clock for I <sup>2</sup> C | # 3.2 PgOta # 3.2.1 P LGA (Land Grid Array) ### 3.2.2 PkOtDiay 2.0mm (Length)\*2.0mm (Width)\*0.95mm (Height) Rev: C **DEXIL B** Rev: C | | [ | OIMENSION | V | | IMENSIO | ٧ | |--------|----------|-----------|-------|-------|---------|-------| | SYMBOL | | (MM) | | | (inch) | | | | MIN. | NØM. | MAX. | MIN. | NOM. | MAX. | | Α | 0.90 | 0.95 | 1.00 | 0.035 | 0.037 | 0.039 | | С | 0.16 | 0.20 | 0.24 | 0.006 | 0.008 | 0.009 | | ъ | 0,20 | 0.25 | 0.30 | 0.008 | 0.010 | 0.012 | | D | 1.95 | 2.00 | 2.05 | 0.077 | 0.079 | 0.081 | | D1 | , | 1.80 BSC | ; | C | .071 BS | С | | E | 1.95 | 2.00 | 2.05 | 0.077 | 0.079 | 0.081 | | E1 | 1.80 BSC | | | C | .071 BS | С | | L | 0.225 | 0.275 | 0.325 | 0.010 | 0.012 | 0.014 | ### Fig. Ptotoiny ### 3.2.3 Mg 6981 YCCC • SP Fig.1. MigFten | ₩ <b>Æ</b> | Dþ | Cten | | |------------|-----------------------------|------------------------------------------------------------|--| | Line 1 | Product Name | "6981" stand for QMA6981 | | | Line 2 | Y: the last digital of year | Lot code: 3 alphanumeric digits, variable to generate mass | | | | CCC: lot code | production trace-code | | | Line3 | P: Part number | P: 1 alphanumeric digit, variable to identify part number | | | | S: Sub-con ID | S: 1 alphanumeric digit, variable identify sub-con | | | • | Pin 1 identifier | | | Rev: C # 4 EKNAL CONNECTON ### 4.1 DHBCt ### 4.2 The information contained herein is the exclusive property of QST, and shall not be distributed, reproduced, or disclosed in whole or in part without prior written permission of QST. ### 5 BASC DENCE OPERTON #### 5.1 Ats The QMA6981 acceleration sensor circuit consists of tri-axial sensors and application specific support circuits to measure the acceleration of device. When a DC power supply is applied to the sensor, the sensor converts any accelerating incident in the sensitive axis directions to charge output. ### 5.2 Pulling Device has two power supply pins. VDD is the main power supply for all of the internal blocks, including analog and digital. VDDIO is a separate power supply, for digital interface only. The device contains a power-on-reset generator. It generates reset pulse as power on, which can load the register's default value, for the device to function properly. To make sure the POR block functions well, we should have such constrains on the timing of VDD and VDDIO. The device should turn-on both power pins in order to operate properly. When the device is powered on, all registers are reset by POR, then the device transits to the standby mode and waits for further commends. Table 6 provides references for four power states. **16** P **16** () +6() ±5. (5 44524.6() ±13.6.1(9) ±8.9(12() ±1()6.1( d **9**0 388.531.3892 1 T673.82 .428.3888.5316389 1 T673 Rev: C | Pten | <b>5</b> 0 | CR | Min | 7 | Ma | b | |---------------------------|------------|---------------------------------------------------------------------------------------------------------------------|-----|---|-----|----| | POR<br>Completion<br>Time | PORT | Time Period After VDD and VDDIO at Operating Voltage to Ready for I <sup>2</sup> C Commend and Analogy Measurement. | | | 250 | μs | | Power off<br>Voltage | SDV | Voltage that Device Considers | | | | | Rev: C ### 6 MODESOF OPERION ### 6.1 Me QMA6981 has two different operational modes, controlled by register (0x11), MODE\_BIT. The main purpose of these modes is for power management. The modes can be transited from one to another, as shown below, through $I^2C$ commands. The default mode after power-on is standby mode. Fig. Biellingen The default mode after power on is standby mode. Through I<sup>2</sup>C instruction, device can switch between standby mode and active mode. With SOFTRESET by writing 0xB6 into register 0x36, all of the registers will get default values. SOFTRESET can be done both in active mode and in standby mode. Also, by writing 1 in NVM\_LOAD (0x33<3>) when device is in active mode, the NVM related image registers will get default value from NVM, however, other registers will keep the values of their own. Rev: C Fig. The ### 6.2 DistMel #### 6.2.1 AtMd In active mode, there are two states, run state, and sleep state. #### 6.2.1.1 In sleep state, whole signal chain is off, including analog and digital signal conditioning, and the rest blocks are on. #### 6.2.1.2 B In run state, the ADC digitizes the charge signals from transducer, and digital signal processor conditions these signals in digital domain, processes the interrupts, and send data to FIFO (accessible through register 0x3F) and Data registers (0x01~0x06). After the signal conditioning, the signal chain will be off and device enters back into sleep state, leaves timer and FSM on. Also in sleep state, reference and power blocks are on. This mode can also be called as power cycling. The power cycling duty is configurable through state registers SLEEP\_DUR (0x11<3:0>). Device can enter into active mode by setting MODE\_BIT (0x11<7>) to logic 1. Besides the power cycling, device can also be configured as FULLRUN, by setting SLEEP\_DUR=0000b. In this setting, no sleep state in the active mode, and device consumes most power, deliver the data most frequently. #### 6.2.2 **M**ed In standby mode, most of the blocks are off, while device is ready for access through I<sup>2</sup>C. Standby mode is the default mode after power on or soft reset. Device can enter into this mode by set the soft reset register (0x36) to 0xB6 or set the MODE\_BIT (0x11<7>) to logic 0. Besides the above two modes, the device also contains NVM loading state. This state is used to reset the value of the NVM related image registers. There are two bits related to this state. When NVM\_LOAD (0x33<3>) is set to 1, NVM loading starts. When the device is in NVM loading state, NVM\_RDY (0x33<2>) is set to logic 0 by device. After NVM loading is finished, NVM\_RDY (0x33<2>) is set back to logic 1 by device, and NVM\_LOAD is reset to 0 ### 7 Ftst ASIC support interrupts, such as POL\_INT, FOB\_INT, STEP\_INT, TAP\_INT, LOW-G, HIGH-G, DRDY\_INT, and FIFO INT. #### 7.1 POLINT The POL\_INT stands for Portrait or Landscape interrupt. It responds to the device in portrait direction or landscape direction. It includes 4 different event types, left, right, up and down events. The different type event stored and can be read from register ORIENT (0x0D<2:0>). | POLA(0@D<2:0>) | Lŧ | <b>B</b> . | Dow | þ | <b>t</b> n | |----------------|----|------------|-----|---|-----------------| | 000 | 0 | 0 | 0 | 0 | unknown | | 001 | 1 | 0 | 0 | 0 | Left/Landscape | | 010 | 0 | 1 | 0 | 0 | Right/Landscape | | 101 | 0 | 0 | 1 | 0 | Down/portrait | | 110 | 0 | 0 | 0 | 1 | Up/portrait | All different events can be detected by comparing the threshold set by register UD\_X\_TH(0x2D),RL\_Y\_TH(0x2F) with the sensor data, also have dependency on comparing result between the Z sensor readings and the register UD\_Z\_TH(0x2C) and RL\_Z\_TH(0x2E). Hysteresis can be introduced to the angle by decreasing a small offset for the threshold registers. All angle data inside the Hysteresis area will be regarded as unknown status in the orient status register (0x0D<2:0>). Below Table shows the condition four kinds of orient events generation, the default threshold for X, Y is set to 40 degrees | Eta | X | | Υ | | Z | |----------|------------|------|------------|------|--------------------------------| | þ | X >UD_X_TH | X <0 | | | Z <ud_z_th< th=""></ud_z_th<> | | Dow | X >UD_X_TH | X >0 | | | Z <ud_z_th< th=""></ud_z_th<> | | <b>5</b> | | | Y >RL_Y_TH | Y <0 | Z <rl_z_th< th=""></rl_z_th<> | | Lé | | | Y >RL_Y_TH | Y >0 | Z <rl_z_th< th=""></rl_z_th<> | For the registers settings, all the orient events threshold 1 LSB bit stand for 3.9mg. For Z axis, it is 8-bit signed 2's complement number ranged from 0.3g to 1.29g, default value 0 as stands for 0.8g. X, Y axis are unsigned data, default value A4 stands for 640mg which angel be regards as 40 degree ,there will be around 10 degree dead band left. The degree value for event can be calculated by the equal asin(0.0039\*UD\_X\_TH) or asin(0.0039\*RL\_Y\_TH). The related interrupt status bit is ORIENT\_INT (0x0A<6>). When the POL status changes the value of ORIENT\_INT will be set to logic 1, and this will be cleared after the interrupt status register is read by user. ORIENT\_EN (0x16<6>) is the enable bit for the POL\_INT. Also, to get this interrupt on PIN\_INT1 and/or PIN\_INT2, we need to set INT1\_ORIENT (0x19<6>) or INT2\_ORIENT (0x1B<6>) to logic 1, to map the internal interrupt to the interrupt PINs. #### 7.2 FOBINT The Front/back event can be detected by comparing Z axis data with a low g value, ranged from 0.1g to 0.6g, which is defined by FB Z TH(0x30<6:0>). The comparing condition shows below: | The information contained herein is the exclusive property of QST, and shall not be distributed, reproduced, or disclosed in whole or in part without prior written permission of QST. | 14 / 34 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| Rev: C | Eta | Χ | Y | Z | |-------|---|---|--------------| | Front | | | Z >FB_TH Z>0 | | Back | | | Z >FB_TH Z<0 | The 2 different type events are stored and can be read from register ORIENT (0x0D<4:3>) | FOB(0QD<4:3>) | a | |---------------|----------| | 00 | unknown | | 01 | Front | | 10 | Back | | 11 | Reserved | Angle between the Z-axis and g can have the relationship: Acc\_Z=1g \* cos(theta). Each threshold will introduce a dark area, which the Front/Back status cannot be recognized, the dark area angel is +/- (90-theta). When the threshold register value is 0x00, the default value stands for 0.1g, and 1 LSB is 3.91mg. The minimum angel between sensor and g direction should be 84 degree, so the dark area should be $\pm$ -6 degree. When the value is 0x7F, the dark area should be $\pm$ -37 degree. The related interrupt status bit is FOB\_INT (0x0A<7>). When the FOB status changed, the value of FOB\_INT will be set to logic 1, and this will be cleared after the interrupt status register is read by user. FOB\_EN (0x16<7>) is the enable bit for the FOB\_INT. Also, to get this interrupt on PIN\_INT1 and/or PIN\_INT2, we need to set INT1\_FOB (0x19<7>) or INT2\_FOB (0x1B<7>) to logic 1, to map the interrupt to the interrupt PINs. ### 7.3 **EP/EPQINT** The STEP/STEP\_QUIT detect that the user is entering/exiting step mode. When the user enter into step mode, at least one axis sensor data will vary periodically, by numbering the variation periods the step counter can be calculated. Fig 0. 16P/16PLT Median data (max+min) /2 is called dynamic threshold, the max and min data can be updated by certainly samples, the sample number can be set by register STEP\_SAMPLE\_CNT (0x12<4:0>). When the sensor data decreasing (or increasing) through the dynamic threshold, a user run step is detected. | The information contained herein is the exclusive property of QST, and shall not be distributed, | |--------------------------------------------------------------------------------------------------| | reproduced, or disclosed in whole or in part without prior written permission of QST. | | مهر | QMA6981<br>Datasheet | Rev: C | |-----|----------------------|--------| |-----|----------------------|--------| Fig 1. Tiple The parameters TAP\_SHOCK (0x2A<6>) and TAP\_QUIET (0x2A<7>) are affected in both single tap and double tap detection, while TAP\_DUR (0x2A<2:0>) is affected in double tap detection only. Within the duration of TAP\_SHOCK, any slope exceeding TAP\_TH (0x2B<4:0>) after the first event will be ignored. Contrary to this, within duration of TAP\_QUIET, no slope exceeding TAP\_TH must occur; otherwise the first event will be cancelled. A single tap interrupt is generated after the combined duration of TAP\_SHOCK and TAP\_QUIET. The interrupt is cleared after a delay of 12.5ms. A double tap interrupt is generated if an event fulfilling the conditions for a single tap occurs within the duration defined by TAP\_DUR after the completion of the first tap event. The interrupt is cleared after a delay of 12.5ms. For each of parameter TAP\_SHOCK and TAP\_QUIET two values are selectable. By writing '0' ('1') to bit TAP\_SHOCK, the duration of TAP\_SHOCK is set to 50ms (75ms). By writing '0' ('1') to bit TAP\_QUIET, the duration of TAP\_QUIET is set to 30ms (20ms). The duration of TAP\_DUR can be set by TAP\_DUR bits: | TAP_DUR | Duration of TAP_DUR | |---------|---------------------| | 000 | 50ms | | 001 | 100ms | | 010 | 150ms | | 011 | 200ms | | 100 | 250ms | | 101 | 375ms | | 110 | 500ms | | 111 | 700ms | The axis which triggered the interrupt is indicated by bits TAP\_FIRST\_X (0x0C<4>), TAP\_FIRST\_Y (0x0C<5>), and HIGH\_FIRST\_Z (0x0C<6>). The bit corresponding to the triggering axis contains a '1' while the other bits hold a '0'. These bits hold until new interrupt is triggered. The sign of the triggering acceleration is stored in bit TAP\_SIGN (0x0C<7>). If the (0x0C) HIGH\_SIGN = '0' ('1'), the sign is positive (negative). This bit holds until a new interrupt is triggered. | The information contained herein is the exclusive property of QST, and shall not be distributed, | 17 / 34 | |--------------------------------------------------------------------------------------------------|---------| | reproduced, or disclosed in whole or in part without prior written permission of QST. | 1,,, | Rev: C ### 7.5 LOWINT The low-g interrupt is based on the comparison of acceleration data against a low-g threshold for the detection of free-fall The low-g interrupt is enabled (disabled) by writing logic '1' ('0') to bits LOW\_EN (0x17<3>). There are two modes available, 'single' mode and 'sum' mode. In 'single' mode, the acceleration of each axis is compared with the threshold; in 'sum' mode, the sum of absolute value of all accelerations acc\_x + acc\_y + acc\_z is compared with the threshold. The mode is selected by the contents of the LOW\_MODE bit (0x24<2>): '0' means 'single' mode, '1' means 'sum' mode. The low-g threshold is set through the LOW\_TH (0x23<7:0>) register. 1 LSB of LOW\_TH always corresponds to an acceleration of 7.8mg (increment is independent from g-range setting). A hysteresis can be set with the LOW\_HYST bits (0x24<1:0>). 1 LSB of LOW\_HYST always corresponds to an acceleration of 125mg (as well, increment is independent from g-range setting). The low-g interrupt is generated if the absolute values of the acceleration of all axes ('and' relation, in case of 'single' mode) or their sum (in case of 'sum' mode) are lower than the threshold for at least the time defined by the LOW\_DUR (0x22<7:0>) register. The interrupt is reset if the absolute value of the acceleration of at least one axis ('or' relation, in case of 'single' mode) or the sum of absolute values (in case of 'sum' mode) is higher than the threshold plus the hysteresis for at least one data acquisition. The relation between the content of LOW\_DUR and the actual delay of the interrupt generation is delay = [LOW\_DUR+1]\*2ms. The interrupt status is stored in bit LOW\_INT (0x0B<3>). ### 7.6 HIGH-GINT The high-g interrupt is based on the comparison of acceleration data against a high-g threshold for the detection of shock or other high-acceleration events. The high-g interrupt is enabled (disabled) per axis by writing logic '1' ('0') to bits HIGH\_EN\_X (0x17<0>), HIGH\_EN\_Y (0x17<1>), and HIGH\_EN\_Z (0x17<2>), respectively. The high-g threshold is set through the HIGH\_TH (0x26<7:0>) register. The meaning of an LSB of HIGH\_TH depends on the selected g-range: it corresponds to 7.8mg in 2g-range (15.6mg in 4g-range, 31.2mg in 8g-range). A hysteresis can be set with the HIGH\_HYST bits (0x24<7:6>). Analogously to the HIGH\_TH, the meaning of an LSB of HIGH\_HYST depends on the selected g-range: it corresponds to 125mg in 2g-range (250mg in 4g-range, 500mg in 8g-range). The high-g interrupt is generated if the absolute value of the acceleration data of at least one of the enabled axes ('or' relation) is higher than the threshold for at least the time defined by the HIGH\_DUR register (0x25<7:0>). The interrupt is reset if the absolute value of the acceleration of all enabled axes ('and' relation) is lower than the threshold minus the hysteresis. The relation between the content of HIGH\_DUR and the actual delay of the interrupt generation is delay = [HIGH\_DUR+1]\*2ms. The interrupt status is stored in bit HIGH\_INT (0x0B<2>). The axis which triggered the interrupt is indicated by bits HIGH\_FIRST\_X (0x0C<0>), HIGH\_FIRST\_Y (0x0C<1>), and HIGH\_FIRST\_Z (0x0C<2>). The bit corresponding to the triggering axis contains a '1' while the other bits hold a '0'. These bits hold until new interrupt is triggered. The sign of the triggering acceleration is stored in bit HIGH\_SIGN (0x0C<3>). If the (0x0C) HIGH\_SIGN = '0' ('1'), the sign is positive (negative). This bit holds until new interrupt is triggered. #### **7.7 DRINT** The width of the acceleration data is 10 bits, in two's complement representation. The data of each axis is split into 2 parts, the MSB part (one byte contains bit 9 to bit 2) and the LSB part (one byte contains bit 1 to bit 0). Reading data should start with LSB part. When user is reading the LSB byte of data, to ensure the integrity of the acceleration data, the content of MSB can be locked, by setting SHADOW\_DIS (0x21<6>) to logic 0. This lock function can be disabled by setting SHADOW\_DIS to logic 1. Without lock, the MSB and LSB content will be Rev: C Also, the user should note that even with SHADOW\_DIS=0, the data of 3 axes are not guaranteed from the same time point. If the user need all of the 3 axes data from the same time point, please use FIFO. For detailed information, the user can refer to 6.8. If SLEEP\_DUR is set to be 0000, then the data can be filtered by low-pass filter, with bandwidth is set by BW (0x10<4:0>). If SLEEP\_DUR is set to be other values, the data also can be averaged in different way (set by BW). In any conditions, the data stored in data registers are offset-compensated. The device supports four different acceleration measurement ranges. The range is setting through RANGE (0x0F<3:0>), and the details as following: | RANGE | Acceleration range | Resolution | |--------|--------------------|------------| | 0001 | 2g | 3.9mg/LSB | | 0010 | 4g | 7.8mg/LSB | | 0100 | 8g | 15.6mg/LSB | | Others | 2g | 3.9mg/LSB | The interrupt for the new data serves for the synchronous data reading for the host. It is generated after storing a new value of z-axis acceleration data into data register. This interrupt will be cleared automatically when the next data conversion cycle starts, when SLEEP\_DUR is not set to 0000b. When device is in full run (SLEEP\_DUR=0000), the interrupt will be effective about 128us, and automatically cleared. The interrupt mode for the new data is fixed to be non-latched. ### 7.8 FIFOINT The device has integrated FIFO memory, capable of storing up to 32 frames, with each frame contains three 10 bits words, for acceleration data of x, y, and z axis. All of the 3 axes' acceleration is sampled at same point in time line The FIFO can be configured as three modes, FIFO mode, STREAM mode, and BYPASS mode. FIFO mode. In FIFO mode, the acceleration data of selected axes are stored in the buffer memory. If enabled, a watermark interrupt can be triggered when the buffer filled up to the defined level. The buffer will continuously be filled until the fill level reaches to 32. When the buffer is full, data collection stops, and the new data will be ignored. Also, FIFO\_FULL interrupt will be triggered when enabled. STREAM mode In STREAM mode, the acceleration data of selected axes will be stored into the buffer until the buffer is full. The buffer's depth is 31 now. When the buffer is full, data collection continues, and the oldest data is discarded. If enabled, a watermark interrupt will be triggered when the fill level reached to the defined level. Also, when buffer is full, FIFO\_FULL interrupt will be triggered if enabled. If any old data is discarded, the FIFO\_OR (0x0E<7>) will be set to be logic 1. BYPASS mode In BYPASS mode, only the current acceleration data of selected axes can be read out from the FIFO. The FIFO acts like the STREAM mode with a depth of 1. Compare to reading directly from data register, this mode has the advantage of ensuring the package of xyz data are from same point of time line. The data registers are updated sequentially and have chance for the xyz data sampled in different time. Also, if any old data is discarded, the FIFO\_OR will be set to be logic 1, similar as that in stream mode. The FIFO mode can be configured by setting FIFO\_MODE (0x3E<7:6>). | FIFO_MODE | Mode | | | | | | | | |-----------|--------|--|--|--|--|--|--|--| | 00 | BYPASS | | | | | | | | | 01 | FIFO | | | | | | | | | 10 | STREAM | | | | | | | | | 11 | FIFO | | | | | | | | Rev: C User can select the acceleration data of which axes to be stored in the FIFO. This configuration can be done by setting FIFO\_CH (0x3E<1:0>), where '00b' for x-, y-, and z-axis, '01b' for x-axis only, '10b' for y-axis only, '11b' for z-axis only. If all the 3 axes data are selected, the format of data read from 0x3F is as follows | XLSB | XMSB | YLSB | YMSB | ZLSB | ZMSB | |------|------|------|------|------|------| These comprise one frame If only one axis is enabled, the format of data read from 0x3F is as follows | YLSB | YMSB | |------|------| These comprise one frame If the frame is not read completely, the remaining parts of the frame will be discarded. If the FIFO is read beyond the FIFO fill level, all zeroes will be read out. FIFO\_FRAME\_COUNTER (0x0E<6:0>) reflects the current fill level of the buffer. If additional data frames are written into the buffer when the FIFO is full (in Stream mode or Bypass mode), then, FIFO\_OR (0x0E<7>) is set to 1. This FIFO\_OR can be considered as flag of discarding old data. When a write access to one of the FIFO configuration registers (0x3E) or (0x31) occurs, the FIFO buffer will be cleared, the FIFO fill level indication register FIFO\_FRAME\_COUNTER (0x0E<6:0>) will be cleared, and the FIFO\_OR (0x0E<7>) will be cleared. As mentioned, FIFO controller contains two interrupts, FIFO\_FULL interrupt, and watermark interrupt. These two interrupts are functional in all the FIFO operating modes. The watermark interrupt is triggered when the fill level of buffer reached to the level that is defined by register FIFO\_WM\_TRIGGER (0x31<5:0>), if the interrupt is enabled by setting INT\_FWM\_EN (0x17<6>) to logic 1 and INT1\_FWM (0x1A<1>) or INT2\_FWM (0x1A<6>) is set. The FIFO\_FULL interrupt is triggered when the buffer has been fully filled. In FIFO-5n8(the)-6.8(rflu5588(7e.7F(rd))+4)-61/28))-67.24(th))+8 Rev: C In latched mode, the clearings of the interrupt status and selected pin are determined by INT\_RD\_CLR (0x21<7>). If INT\_RD\_CLR=0, read operation to the INT\_STAT will clear the interrupt and the selected pin. If INT\_RD\_CLR=1, any read operation to the device will clear the interrupt and the selected pin. If the condition for trigging the interrupt still holds, the interrupt status will be set again with the next change of the data registers. Mapping the interrupt pins can be set by INT\_MAP (0x19~0x1B). The electrical interrupt pins can be set in INT\_PIN\_CONF (0x20<3:0>). The active logic level can be set to 1 or 0, and the interrupt pin can be set to open-drain or push-pull. If the interrupt mode is configured as latched mode, the interrupt can also be cleared by $I^2C$ reading any of the interrupt status register (0x09 ~ 0x0c). # 8 I<sup>2</sup>C COMMNICATION PROTOCOL 8.1 I<sup>2</sup>C in Table 9 and Figure 12 describe the I<sup>2</sup>C communication protocol times **ID**. I <sup>2</sup>C ∰ n Pten Sin Cti Min Rev: C NACK: If the receiver doesn't pull down the SDA line during the high period of the acknowledge clock cycle, it's recognized as NACK by the transmitter. #### 8.2.3 I<sup>2</sup>C W I<sup>2</sup>C write sequence begins with start condition generated by master followed by 7 bits slave address and a write bit (R/W=0). The slave sends an acknowledge bit (ACK=0) and releases the bus. The master sends the one byte register address. The slave again acknowledges the transmission and waits for 8 bits data which shall be written to the specified register address. After the slave acknowledges the data byte, the master generates a stop signal and terminates the writing protocol. #### ■1. I <sup>2</sup>C ₩ | ST | Slave Address | V V | SΑ | Regis | ster Ad<br>(0x11) | dress | ςA | | Data<br>(0x80) | 18 | LS | |-----|---------------|-----|-----|-------|-------------------|-------|-----|-------|----------------|------------|----| | ART | 0 0 1 0 0 1 0 | 0 | Ś C | 0 0 | 1 0 | 0 0 | 1 6 | 1 0 0 | 0 0 0 0 | 이 <u> </u> | OP | #### 8.2.4 I<sup>2</sup>C & $I^2C$ write sequence consists of a one-byte $I^2C$ write phase followed by the $I^2C$ read phase. A start condition must be generated between two phase. The $I^2C$ write phase addresses the slave and sends the register address to be read. After slave acknowledges the transmission, the master generates again a start condition and sends the slave address together with a read bit (R/W=1). Then master releases the bus and waits for the data bytes to be read out from slave. After each data byte the master has to generate an acknowledge bit (ACK = 0) to enable further data transfer. A NACK from the master stops the data being transferred from the slave. The slave releases the bus so that the master can generate a STOP condition and terminate the transmission. The register address is automatically incremented and more than one byte can be sequentially read out. Once a new data read transmission starts, the start address will be set to the register address specified in the current I<sup>2</sup>C write command. #### ■2. I <sup>2</sup>C R | ST | | SI | ave | e Ad | ddre | ess | | R<br>W | s, | | Register Address<br>(0x00) | | | | S/ | | | | | | | | | | | | | | |-------|---|----|-----|------|-------------------|-----|---|--------|------|---|----------------------------|----------------|---|---|----|---|---|------|---|---|---|------------|------------|---|---|---|------|------| | TART | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | SACK | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SACK | | | | | | | | | | | | ST | | SI | ave | e Ad | ddre | ess | I | R<br>W | 1 | | | Data<br>(0x00) | | | | | M | | | | | ata<br>01) | | | | | | | | START | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | SACK | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | MACK | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | MACK | 0 | 0 | 0 | | Data<br>0x02<br>0 | | 1 | 0 | MACK | | | | | | | | | MACK | | | | | ata<br>07) | | | | NACK | STOP | Rev: C ### **3. 9**Mp | Ox3F | | FI FO_DATA<7: | ^ | | | | | | | R | 00 | | | | |----------------------------------------------------------------------------------------------|------------------------|-----------------------------------------------------------------------------------------------------------|----------------------------|----------------------------|--------------------------------------------------------------------------------------------|------------------------------------|--------------------------|-----------------|---------------------|--------------------------------------|----------------------------------------------|--|--|--| | | | FI FO MODE<1: | | | l | | 1 | FI FO_CHk1: 0> | • | | 00 | | | | | | FIFU_CUNF | | U> | | l | | L | rrro_urki: us | | | | | | | | Ox3D | | GAI N_Z<7: 0> | | | | | | | • | | NMM. | | | | | Ox3C | | GAI N_Y<7: 0> | | | | | | | | | NM | | | | | Ox3B | | GAI N_X<7: 0> | | | | | | | | | MM | | | | | Ox3A | | OFFSET_Z<7: 0 | > | | | | | | | RW | MM | | | | | 0x39 | | CFFSET_Y<7: 0 | > | | | | | | | RW | MM | | | | | 0x38 | | OFFSET_X<7: 0 | > | | | | | | | RW | MM | | | | | 0x37 | I MAGE | OFFSET X<10: | | | CAI | N_Z<9: 8> | | FFSET_Y<10: 8> | | | MM | | | | | | SOFT RESET | SOFTRESET: 0 | | | | | | | | | 00 | | | | | 0x35 | OG I_IEDEI | DOL INEEDEL! | il DO | | | | | | | | 00 | | | | | 0x34 | | | | | | | | | | | 00 | | | | | | NM_CFG | | | | I | NVM LOAD | NAM DEW | NIA DDCC | | | 04 | | | | | | | CELETECT DIT | | | NMM_LOAD NMM_RDY NMM_PROG Si ngl eEn_St ep SELFTEST_SI CN SELFTEST_AXI S<1: 0> | | | | | | | | | | | | | SELFTEST_BIT | | DIEC MAK IN E. | | loruðr eru or eb | DELL'IEST_SIGN | DETLIEDI WY 2 | <1: U> | | 00<br>00 | | | | | | FI FO_VM | COVER DO DE | | FI FO_WIMK_LVL<5: | <u>U&gt;</u> | TD 7 WY 0 0 | | | | | | | | | | 0x30 | | ORIENT DB DI | | | | FB_Z_THk6: 0> | | | | | <u>00</u> | | | | | Ox2F | | | | | | <u>THk7: 0&gt;</u> | | | | RW | A4 | | | | | Ox2E | | | | | | <u>'_THk7: 0&gt;</u> | | | | | $\infty$ | | | | | 0x2D | | | | | | <u>(_THk7: 0&gt;</u> | | | | RW | A4 | | | | | 0x2C | 4D/6D | | | | UD_2 | <u>_THk7: 0&gt;</u> | | | | RW | $\infty$ | | | | | Ox2B | | | | | TAP_THk4: O> | | | | | RW | OA. | | | | | Ox2A | TAP | TAP_QUI ET | TAP_SHOCK | | | | TAP_DUR<2: 0> | | | RW | 04 | | | | | 0x29 | | | | | OS CI | ST_Z<7: 0> | | | | | 00 | | | | | 0x28 | | | | | | ST_Y<7: 0> | | | | | 00 | | | | | | OS_CUST | | | | | ST_X<7: 0> | | | | | $\infty$ | | | | | 0x26 | | HI CH_THx 7: 0> | | | <u> </u> | DI_/R/1. 02 | | | | | m | | | | | 0x25 | | HI CH_DUR<7: 0 | | | | | | | | RW | OF | | | | | | | | | 1 | 1 | 1 | I OWN ODE | LOWINGT ALO. | | RW | <u>ur</u><br>81 | | | | | 0x24 | | HI CH_HYST<1: | U> | | l | | LOWMODE | LOWHYST<1: 0> | • | | | | | | | 0x23 | | LOWTH: 7: 0> | | | | | | | | | 30<br>09 | | | | | | | LOW DUR< 7: 0> | | T | | | | | | | | | | | | | | INT_RD_CLR | SHADOW DIS | I NT_PULSE | | | | | LATCH_INT | | $\infty$ | | | | | 0x20 | INT_PIN_CONF | | | | | I NT2_CD | I NT2_LVL | | I NT1_LVL | | 05<br>00 | | | | | Ox1F | | | | PEA | K_B<5: 0> STEP_M SMATCH_B<1: 0> | | | | | | | | | | | Ox1E | | | | VALLI | EY_Bx5: 0> | | | | | | | | | | | Ox1D | | | | | | | | | | RW | FF | | | | | Ox1C | | | INT2_FVM | I NI2_FFULL | I NT2_DATA | I NT2_LOW | I NT2_HI CH | | | RW | 00 | | | | | Ox1B | | INT2_FOB | I NT2_ORI ENT | I NT2_S_TAP | I NT2_D_TAP | I NI'2_STEP | I NI 2_STEP_QUI T | INT2 STEP IN | IML | | 00 | | | | | Ox1A | | | INT1 FVM | I NT1 FFULL | I NT1 DATA | INTI LOW | INT1 HIGH | | | | 00 | | | | | | INT MAP | INT1_FOB | I NT1_ORI ENT | I NΓ1_S_TAP | I NT1_D_TAP | I NI 1_STEP | I NT1_STEP_QUI T | INTI STEP INS | IMI | | 00 | | | | | | I NT_SRC | IIII_ICD | INT_SRC_STEP | I NT_SRC_DATA | INT_SRC_TAP | IIIII_SILL | 11111_51111_4011 | IIIII_DIM_GO | 1 141 12 | | 00 | | | | | 0x17 | IN_SIC | | INT FUMEN | INT FFULL EN | DATA_EN | LOWEN | HICH EN Z | HIGH EN Y | HI CHLEN X | | 00 | | | | | | INT ENI | EOD EN | | | | | | | | | 00 | | | | | | I NI_EN | FOB_EN | ORI ENI_EN | S_TAP_EN | D_TAP_EN | STEP_EN | STEP_QUIT_EN | STEP_UNSI MI LA | Rr EIA | | œ<br>œ | | | | | 0x15 | | | | | STEP_TI ME_UP<7: 0> | | | | | | | | | | | 0x14 | OTTED 007.5 | COMPANY CO. T. | | | STEP_TI ME_LOW7: 0> | | | | | | | | | | | | STEP_CONF | STEP_CLR | | | STEP_PRECISION-6: 0> | | | | | | | | | | | 0x12 | | STEP_START | | | STEP_SAMPLE_COUNT<4: 0> | | | | | | | | | | | | | MODE_BIT | RESV | PRESET< | 1: 0> | SLEEP_DUR<3: 0> | | | | | 00 | | | | | 0x10 | | | | CDRH | | | BW:4: 0> | | | | $\infty$ | | | | | | FULL SCALE | | | | | RANCE<3: 0> | | | | | $\infty$ | | | | | OxOE | FI FO STATUS | FI FO_CR | FI FO_FRAME_CO | JUNIER<6: 0> | | | | | | R | $\infty$ | | | | | | | | | | F( | OB<1: 0> | | ORI ENT<2: 0> | | | 00 | | | | | OxOD | | STEP_CNT_OVF | <u> </u> | | | | | | HICH_FIRST_X | R | $\infty$ | | | | | OxOD<br>OxOC | | | TAP_FI RST_Z | TAP_FI RST_Y | TAP_FI RST_X | HICHLSICN | HIGH_FIRST_Z | HIGHTH KOTI | | 10 | | | | | | | | STEP_CNT_OVE | TAP_FIRST_Z | | TAP_FIRST_X<br>DATA INT | <u> HI CH_SI GN</u><br> LOWI NT | HICH_FIRST_Z<br>HICH INT | HIGH_FIRSI_Y | II GILIII DI A | | 00 | | | | | OxOC<br>OxOB | - | STEP_CNT_OVE<br>TAP_SI CN | TAP_FIRST_Z<br>FIFO_WM_INT | FI FO_FULL_I NT | DATA_I NI | LOWINT | HI CHLINT | | | R | | | | | | OxOC<br>OxOB | - | STEP_CNT_OVE | TAP_FIRST_Z | | | | | | | R<br>R | 00<br>00<br>FF | | | | | OxOC<br>OxOB<br>OxOA<br>OxO9 | - | STEP_CNT_OVE<br>TAP_SI CN | TAP_FIRST_Z<br>FIFO_WM_INT | FI FO_FULL_I NT | DATA_I NT<br>D_TAP_I NT | LOWI NT<br>STEP_I NT | HI CHLINT | | | R<br>R<br>R | 00<br>FF | | | | | 0x0C<br>0x0B<br>0x0A<br>0x09<br>0x08 | I NI_STATUS | STEP_CNT_OVE<br>TAP_SI CN | TAP_FIRST_Z<br>FIFO_WM_INT | FI FO_FULL_I NT | DATA_INT D_TAP_INT STEP | LOWI NT<br>STEP_I NT<br>CNI<15: 8> | HI CHLINT | | | R<br>R<br>R | 00<br>FF<br>00 | | | | | 0x0C<br>0x0B<br>0x0A<br>0x09<br>0x09<br>0x08 | INT_STATUS STEP ONT | STEP_CNI_OVF<br>TAP_SI CN<br>FOB_I NIT | TAP_FIRST_Z<br>FIFO_WM_INT | FI FO_FULL_I NT | DATA_INT D_TAP_INT STEP | LOWI NT<br>STEP_I NT | HI CHLINT | | | R<br>R<br>R<br>R | 00<br>FF<br>00<br>00 | | | | | 0x0C<br>0x0B<br>0x0A<br>0x09<br>0x09<br>0x08<br>0x07<br>0x06 | INT_STATUS STEP ONT | STEP_CNI_OVF<br>TAP_SI GN<br>FOB_I NIT<br>ACC_Z<9: 2> | TAP_FIRST_Z<br>FIFO_WM_INT | FI FO_FULL_I NT | DATA_INT D_TAP_INT STEP | LOWI NT<br>STEP_I NT<br>CNI<15: 8> | HI CHLINT | STEP_UNSI M LA | I<br>IR | R<br>R<br>R<br>R<br>R | 00<br>FF<br>00<br>00 | | | | | 0x0C<br>0x0B<br>0x0A<br>0x09<br>0x08<br>0x07<br>0x06<br>0x05 | INT_STATUS STEP ONT | STEP_CNI_OWF TAP_SI GN FOB_I NT ACC_Z<9: 2> ACC_Z<1: 0> | TAP_FIRST_Z<br>FIFO_WM_INT | FI FO_FULL_I NT | DATA_INT D_TAP_INT STEP | LOWI NT<br>STEP_I NT<br>CNI<15: 8> | HI CHLINT | STEP_UNSI M LA | | R<br>R<br>R<br>R<br>R<br>R | 00<br>FF<br>00<br>00<br>00 | | | | | 0x0C<br>0x0B<br>0x0A<br>0x09<br>0x08<br>0x07<br>0x06<br>0x05<br>0x04 | INT_STATUS STEP ONT | STEP_CNI_OVF TAP_SI GN FOB_INI ACC_Z<9: 2> ACC_Z<1: 0> ACC_Y<9: 2> | TAP_FIRST_Z<br>FIFO_WM_INT | FI FO_FULL_I NT | DATA_INT D_TAP_INT STEP | LOWI NT<br>STEP_I NT<br>CNI<15: 8> | HI CHLINT | STEP_UNSI M LA | R<br>R<br>NEWDATA_Z | R<br>R<br>R<br>R<br>R<br>R<br>R | 00<br>FF<br>00<br>00<br>00<br>00 | | | | | 0x0C<br>0x0B<br>0x0A<br>0x09<br>0x08<br>0x07<br>0x06<br>0x05<br>0x04<br>0x03 | INT_STATUS STEP ONT | STEP_CNI_OVF TAP_SI GN FOB_INT ACC_Z<9: 2> ACC_Z<1: 0> ACC_Y<9: 2> ACC_Y<1: 0> | TAP_FIRST_Z<br>FIFO_WM_INT | FI FO_FULL_I NT | DATA_INT D_TAP_INT STEP | LOWI NT<br>STEP_I NT<br>CNI<15: 8> | HI CHLINT | STEP_UNSI M LA | R<br>NEWDATA Z | R<br>R<br>R<br>R<br>R<br>R<br>R | 00<br>FF<br>00<br>00<br>00<br>00<br>00 | | | | | 0x0C<br>0x0B<br>0x0A<br>0x09<br>0x08<br>0x07<br>0x06<br>0x05<br>0x04<br>0x03<br>0x02 | INT_STATUS<br>STEP_CNT | STEP_CNI_OVF TAP_SI GN FOB_I NI ACC_Z<9: 2> ACC_Z<1: 0> ACC_Y<9: 2> ACC_Y<9: 2> ACC_X<1: 0> ACC_X<9: 2> | TAP_FIRST_Z<br>FIFO_WM_INT | FI FO_FULL_I NT | DATA_INT D_TAP_INT STEP | LOWI NT<br>STEP_I NT<br>CNI<15: 8> | HI CHLINT | STEP_UNSI M LA | R NEWDATA_Z | R<br>R<br>R<br>R<br>R<br>R<br>R<br>R | 00<br>FF<br>00<br>00<br>00<br>00<br>00<br>00 | | | | | 0x0C<br>0x0B<br>0x0A<br>0x09<br>0x08<br>0x07<br>0x06<br>0x05<br>0x04<br>0x03<br>0x02<br>0x01 | INT_STATUS<br>STEP_CNT | STEP_CNI_OVF TAP_SI GN FOB_INT ACC_Z<9: 2> ACC_Z<1: 0> ACC_Y<9: 2> ACC_Y<1: 0> | TAP_FIRST_Z<br>FIFO_WM_INT | FIFO FULL INT<br>S_TAP_INT | DATA I NT D TAP_I NT STEP_ STEP | LOWI NT<br>STEP_I NT<br>CNI<15: 8> | H GH INT STEP_QUIT_INT | STEP_UNSI M LA | R<br>R<br>NEWDATA_Z | R<br>R<br>R<br>R<br>R<br>R<br>R<br>R | 00<br>FF<br>00<br>00<br>00<br>00<br>00<br>00 | | | | Rev: C ### 9.2 **5**0 **b** Register 0x00 (CHIP ID) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |-------------|------|------|------|------|------|------|------|-----|---------| | Device ID R | | | | | | | | RW | 0xBX | This register is used to identify the device | Register Uni | $JI \sim 0 \times 0 \times (D)$ | (L, DAIVI) | | | | | | | | |--------------|---------------------------------|------------|------|------|------|------|------|-----|---------| | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | Rev: C FIFO\_WM\_INT: 1, FIFO watermark interrupt active 0, FIFO watermark interrupt inactive FIFO\_FULL\_INT: 1, FIFO full interrupt active 0, FIFO full interrupt inactive DATA\_INT: 1, data ready interrupt active 0, data ready interrupt inactive LOW\_INT: 1, low-g interrupt active 0, low-g interrupt inactive HIGH\_INT: 1, high-g interrupt active 0, high-g interrupt inactive Register 0x0c (INT\_STAT2) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |---------|---------|---------|---------|---------|---------|---------|---------|-----|---------| | TAP_SIG | TAP_FIR | TAP_FIR | TAP_FIR | HIGH_SI | HIGH_FI | HIGH_FI | HIGH_FI | R | 0x00 | | N | ST Z | ST Y | ST X | GN | RST Z | RST Y | RST X | | | TAP\_SIGN: 1, sign of tap triggering is negative TAP\_FIRST\_Z: 7. sign of tap triggering signal is positive to take the following signal is positive to the following signal is positive to the following signal is positive to the following signal is positive to the following signal is positive to the following signal is positive to take the following signal is positive to signal is positive to the following signal is positive to the following signal HIGH\_SIGN: 1, sign of high-g triggering signal is negative 0, sign of high-g triggering signal is positive HIGH\_FIRST\_Z: 1, high-g interrupt is triggered by Z axis 0, high-g interrupt is not triggered by Z axis HIGH\_FIRST\_Y: 1, high-g interrupt is triggered by Y axis 0, high-g interrupt is not triggered by Y axis HIGH\_FIRST\_X: 1, high-g interrupt is triggered by X axis 0, high-g interrupt is not triggered by X axis Register 0x0d (INT\_STAT3) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |---------|------|------|----------|------|-------------|------|------|------|---------| | STEP_CN | | | FOB<1:0> | | ORIENT<2:0> | | R | 0x00 | | | T_OVFL | | | | | | | | | | STEP\_CNT\_OVFL: 1, step counter is over-flowed 0, step counter is not over-flowed FOB<1:0>: 00, device is in unknown orientation 01, device is in front orientation 10, device is in back orientation 11, reserved ORIENT<2:0>: 000, device is in unknown orientation 001, device is in left orientation 010, device is in right orientation 011, reserved 100, reserved 101, device is in down orientation110, device is in up orientation 111, reserved Register 0x0e (FIFO STATE) | - 4 | | | | | | | | | | | | |-----|---------|-----------------------|------|------|------|------|------|------|-----|---------|--| | | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | | | | FIFO OR | FIFO FRAME COUNT<6:0> | | | | | | | R | 0x00 | | 0, FIFO over 1, FIFO over run occurred 0, FIFO over run not occurred FIFO\_FRAME\_COUNT<6:0>: Fill level of FIFO buffer. An empty FIFO corresponds to 0x00. The frame counter can be cleared by reading out all of the frames, or by writing register 0x3e (FIFO\_CFG1) or 0x31. Register 0x0f (RANGE) FIFO\_OR: | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |------|------|------|------|------------|------|------|------|-----|---------| | | | | | RANGE<3:0> | | | | RW | 0x00 | RANGE<3:0>: set the full scale of the accelerometer. Setting as following | The information contained herein is the exclusive property of QST, and shall not be distributed, reproduced, or disclosed in whole or in part without prior written permission of QST. | 26 / 34 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| Rev: C Register 0x10 (BW) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |------|------|------|---------|------|------|------|------|-----|---------| | | | ODRH | BW<4:0> | | | | | RW | 0x00 | ODRH: 1, higher output data rate, ODR = 4\*F\_BW 0, lower output data rate, ODR = 2\*F\_BW bandwidth setting, as following BW<4:0>: Register 0x11 (POWER) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |---------|------|-----------|------|----------------|------|------|------|-----|---------| | MODE_BI | RESV | PRESET<1: | :0> | SLEEP_DUR<3:0> | | | | RW | 0x00 | | T | | | | | | | | | | MODE\_BIT: 1, set device into active mode 0, set device into standby mode User should set this bit to 1. RESV: The information contained herein is the exclusive property of QST, and shall not be distributed, reproduced, or disclosed in whole or in part Rev: C | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |---------|----------|----------|----------|---------|---------|------------------|------|-----|---------| | INT1_FO | INT1_ORI | INT1_S_T | INT1_D_T | INT1_ST | INT1_ST | INT1_ST | | RW | 0x00 | | В | ENT | AP | AP | EP | EP_QUIT | EP_UNSI<br>MILAR | | | | INT1\_FOB: 1, map FOB interrupt to INT1 pin 0, not map FOB interrupt to INT1 pin INT1\_ORIENT: 1, map ORIENT interrupt to INT1 pin 0, not map ORIENT interrupt to INT1 pin INT1\_S\_TAP: 1, map single tap interrupt to INT1 pin 0, not map single tap interrupt to INT1 pin INT1\_D\_TAP: 1, map double tap interrupt to INT1 pin 0, not map double tap interrupt to INT1 pin INT1\_STEP: 1, map step valid interrupt to INT1 pin 0, not map step valid interrupt to INT1 pin INT1\_STEP\_QUIT: 1, map step quit interrupt to INT1 pin 0, not map step quit interrupt to INT1 pin INT1\_STEP\_UNSIMILAR: 1, map step unsimilar interrupt to INT1 pin 0, not map step unsimilar interrupt to INT1 pin #### Register 0x1a (INT\_MAP1) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |------|---------|---------|---------|---------|----------|------|------|-----|---------| | | INT1_FW | INT1_FF | INT1_DA | INT1_LO | INT1_HIG | | | RW | 0x00 | | | М | UH | TA | W | Hs | | | | | INT1\_FWM: 1, map FIFO watermark interrupt to INT1 pin 0, not map FIFO watermark interrupt to INT1 pin INT1\_FFULL: 1, map FIFO full interrupt to INT1 pin 0, not map FIFO full interrupt to INT1 pin INT1\_DATA: 1, map data ready interrupt to INT1 pin 0, not map data ready interrupt to INT1 pin INT1\_LOW: 1, map low-g interrupt to INT1 pin 0, not map low-g interrupt to INT1 pin INT1\_HIGH: 1, map high-g interrupt to INT1 pin 0, not map high-g interrupt to INT1 pin Register 0x1B (INT\_MAP2) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |----------|--------|--------|---------|-------|-----------|------------|------|-----|---------| | INT2_FOB | INT2_ | INT2_S | INT2_D_ | INT2_ | INT2_STEP | INT2_STEP_ | | RW | 0x00 | | | ORIENT | TAP | TAP | STEP | QUIT | UNSIMILAR | | | | INT2\_FOB: 1, map FOB interrupt to INT2 pin 0, not map FOB interrupt to INT2 pin INT2\_ORIENT: 1, map ORIENT interrupt to INT2 pin 0, not map ORIENT interrupt to INT2 pin INT2\_S\_TAP: 1, map single tap interrupt to INT2 pin 0, not map single tap interrupt to INT2 pin 1, map double tap interrupt to INT2 pin 0, not map double tap interrupt to INT2 pin 0, not map double tap interrupt to INT2 pin INT2\_STEP: 1, map step valid interrupt to INT2 pin 0, not map step valid interrupt to INT2 pin INT2\_STEP\_QUIT: 1, map step quit interrupt to INT2 pin 0, not map step quit interrupt to INT2 pin INT2\_STEP\_UNSIMILAR: 1, map step unsimilar interrupt to INT2 pin 0, not map step unsimilar interrupt to INT2 pin #### Register 0x1c (INT\_MAP3) | | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |---|------|---------|----------|---------|---------|---------|----------|------|-----|---------| | ſ | | INT2_FW | INT2_FUL | INT2_DA | INT1_ST | INT2_LO | INT2_HIG | | RW | 0x00 | | | | M | L | TA | EP | W | Н | | | | INT2\_FWM: 1, map FIFO watermark interrupt to INT2 pin 0, not map FIFO watermark interrupt to INT2 pin INT2\_FULL: 1, map FIFO full interrupt to INT2 pin 0, not map FIFO full interrupt to INT2 pin INT2\_DATA: 1, map data ready interrupt to INT2 pin 0, not map data ready interrupt to INT2 pin INT2\_LOW: 1, map low-g interrupt to INT2 pin | The information contained herein is the exclusive property of QST, and shall not be distributed, | |--------------------------------------------------------------------------------------------------| | reproduced, or disclosed in whole or in part without prior written permission of QST. | Rev: C INT2\_HIGH: 0, not map low-g interrupt to INT2 pin 1, map high-g interrupt to INT2 pin 0, not map high-g interrupt to INT2 pin Register 0x20 (INTPIN\_CFG) Bit7 Bit6 Bit5 Bit4 Bit3 Bit2 Bit1 Bit0 R/W Default INT1 OD INT2 OD RW INT2 I VI INT1 0x05 INT2\_OD: 1, open-drain for INT2 pin 0, push-pull for INT2 pin INT2\_LVL: 1, logic high as active level for INT2 pin INT1\_OD: 0, logic low as active level for INT2 pin 1, open-drain for INT1 pin 0, push-pull for INT1 pin 1, logic high as active level for INT1 pin INT1\_LVL: 0, logic low as active level for INT1 pin Register 0x21 (INT CFG) | . togioto, on | _ : (::::_0: 0) | | | | | | | | | |---------------|-----------------|---------|------|------|------|------|---------|-----|---------| | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | | INT_RD_ | SHADOW | INT_PUL | | | | | LATCH_I | RW | 0x00 | | CLR | DIS | SF | | | | | NT | | | INT RD CLR: 1, clear all the interrupts in latched-mode, when any read operation to this device 0, clear all the interrupts, only when read the register INT\_STAT (0x0A~0x0B), no matter the interrupts in latched-mode, or in non-latched-mode SHADOW\_DIS: 1, disable the shadowing function for the acceleration data 0, enable the shadowing function for the acceleration data. When shadowing is enabled, the MSB of the acceleration data is locked, when corresponding LSB of the data is reading. This can ensure the integrity of the acceleration data during the reading. The MSB will be unlocked when the MSB is read. INT\_PULSE: 1, data ready interrupt is kept until next conversion starts, in power cycling 0, pulse of data ready interrupt is fixed to be 128us LATCH\_INT: 1, interrupt is in latch mode 0, interrupt is in non-latch mode Register 0x22 (LOW\_HIGH\_G\_0) | LOW_DUR<7:0> RW 0x09 | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |----------------------|---------|-------|------|------|------|------|------|------|-----|---------| | | LOW_DUR | <7:0> | | | | | | | RW | 0x09 | LOW\_DUR<7:0>: low-g interrupt triggered delay, the actual time is (LOW\_DUR<7:0>+1)\*2ms; the default delay time is 20ms Register 0x23 (LOW\_HIGH\_G\_1) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |---------------------------------------------------------------------------------------------------------------|------|------|------|------|------|------|------|-----|---------| | LOW_TH<7:0> RW 0x30 | | | | | | | | | | | LOW_TH<7:0>: low-g interrupt threshold, the actual g value is (LOW_TH<7:0>)*7.8mg; the default value is 375mg | | | | | | | | | | Register 0x24 (LOW HIGH G 2) | rtogiotoi | regioter ext r (Eerr_riteri_e_e_r) | | | | | | | | | | | | | |----------------|------------------------------------|------|------|------|--------|----------|--------|-----|---------|--|--|--|--| | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | | | | | | HIGH_HYST<1:0> | | | | | LOW_MO | LOW_HYS7 | Γ<1:0> | RW | 0x81 | | | | | | | | | | | DF | | | | | | | | | HIGH\_HYST<1:0>: hysteresis of high-g interrupt, the actual g value is (HIGH\_HYST<1:0>)\*125mg(2g range), (HIGH\_HYST<1:0>)\*250mg (4g range),(HIGH\_HYST<1:0>)\*500mg(8g range) LOW MODE: low-g interrupt mode 1: sum mode 0: single-axis mode, LOW\_HYST<1:0>: hysteresis of low-g interrupt, the actual g value is (LOW\_HYST<1:0>)\*125mg, independent of the selected g range Register 0x25 (LOW\_HIGH\_G\_3) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |----------------------|----------|------------------|----------------|----------------|---------------|------------|---------------|-----------|------------------| | HIGH_DUR<7:0> RW 0xi | | | | | | | | | | | HIGH_DUR | <7:0>: h | nigh-g interrupt | triggered dela | ay, the actual | time is (HIGH | _DUR<7:0>+ | 1)*2ms; the d | efault de | lay time is 32ms | Register 0x26 (LOW HIGH G 4) | Trogiotor ox | 110glotor 0x20 (2011_11011_0_1) | | | | | | | | | | | | |--------------|---------------------------------|------|------|------|------|------|------|-----|---------|--|--|--| | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | | | | | HIGH TH<7.0> | | | | | | | | | 0xC0 | | | | HIGH\_TH<7:0>: high-g interrupt threshold, the actual g value is (HIGH\_TH<7:0>)\*7.8mg(2g range), (HIGH\_TH<7:0>)\*15.6mg(4g range), (HIGH\_TH<7:0>)\*31.2mg(8g range) | The information contained herein is the exclusive property of QST, and shall not be distributed, reproduced, or disclosed in whole or in part without prior written permission of QST. | 30 / 34 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| Rev: C Register 0x27 (OS\_CUST\_X) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |----------------|------|------|------|------|------|------|------|-----|---------| | OS_CUST_X<7:0> | | | | | | | | RW | 0x00 | OS\_CUST\_X<7:0>: offset calibration of X axis for user, the LSB depends on full-scale of the device which is 3.9mg in 2g range, 7.8mg in 4g range, 15.6mg in 8g range Register 0x28 (OS\_CUST\_Y) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |----------------|------|------|------|------|------|------|------|-----|---------| | OS CUST Y<7:0> | | | | | | | | RW | 0x00 | OS\_CUST\_Y<7:0>: offset calibration of Y axis for user, the LSB depends on full-scale of the device which is 3.9mg in 2g range, 7.8mg in 4g range, 15.6mg in 8g range Register 0x29 (OS CUST Z) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |----------------|------|------|------|------|------|------|------|------|---------| | OS CUST Z<7:0> | | | | | | | RW | 0x00 | | OS\_CUST\_Z<7:0>: offset calibration of Z axis for user, the LSB depends on full-scale of the device which is 3.9mg in 2g range, 7.8mg in 4g range, 15.6mg in 8g range Register 0x2a (TAP\_CONF0) | ſ | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |---|---------|--------|------|------|------|----------|------|------|-----|---------| | ſ | TAP_QUI | TAP_SH | | | | TAP_DUR< | 2:0> | | RW | 0x04 | | ı | FT | OCK | | | | | | | | | TAP\_QUIET: tap quiet time, 1: 30ms, 0: 20ms TAP\_SHOCK: tap shock time, 1: 50ms, 0: 75ms TAP\_DUR<2:0>: the time window of the second tap event for double tap | TAP_DUR<2:0> | Duration of TAP_DUR | |--------------|---------------------| | 000 | 50ms | | 001 | 100ms | | 010 | 150ms | | 011 | 200ms | | 100 | 250ms | | 101 | 375ms | | 110 | 500ms | | 111 | 700ms | Register 0x2b (TAP\_CONF1) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |------|------|------|-----------|------|------|------|------|-----|---------| | | | | TAP TH<4: | | | | | | 0x00 | TAP\_TH<4:0>: threshold of single/double tap interrupt, the actual g value is TAP\_TH<4:0>\*62.5mg (2g range), TAP\_TH<4:0>\*125mg(4g range), TAP\_TH<4:0>\*250mg(8g range) Register 0x2c (4D6D\_CONF0) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |--------------|------|------|------|------|------|------|------|-----|---------| | UD Z TH<7:0> | | | | | | | | RW | 0x00 | Rev: C | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | |----------------|------|------|------|------|------|-----------|------|-----|---------| | FIFO_MODE<1:0> | | | | | | FIFO_CH<1 | :0> | RW | 0x00 | FIFO\_MODE<1:0>: FIFO\_MODE defines FIFO mode of the device. Settings as following FIFO\_MODE<1:0> Mode FIFO\_CH<1:0>: FIFO\_CH defines which channel data be stored in FIFO buffer. Setting as following 11, only z axis data be stored in FIFO buffer 10, only y axis data be stored in FIFO buffer 01, only x axis data be stored in FIFO buffer 01, only x axis data be stored in FIFO buffer 00, all axes data be stored in FIFO buffer Register 0x3f (FIFO\_DATA) | | . togioto: ont | <u> </u> | , ,, | | | | | | | | |---|----------------|----------|------|------|------|------|------|------|-----|---------| | П | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | R/W | Default | | | FIFO DATA | 1 | | | | | | | R | 0x00 | FIFO\_DATA: FIFO read out data. User can read out FIFO data through this register. Data format depends on the setting of FIFO\_CH (0x3e<1:0>). When the FIFO data is the LSB part of acceleration data, and if FIFO is empty, then FIFO\_DATA<0> is 0. Otherwise if FIFO is not empty and the data is effective, FIFO\_DATA<0> is 1 when reading LSB of acceleration. Rev: C #### ORDERING INFORMATION | OigNen | | Pla | Plg | |------------|---------|--------|-------------------------------| | QMA6981-TR | -40 ~85 | LGA-12 | Tape and Reel: 5k pieces/reel | #### FIND OTMOR For more information on QST's Accelerometer Sensors contact us at 86-21-50497300. The application circuits herein constitute typical usage and interface of QST product. QST does not provide warranty or assume liability of customer-designed circuits derived from this description or depiction. QST reserves the right to make changes to improve reliability, function or design. QST does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others. ISO9001: 2008 China Patents 201510000399.8, 201510000425.7, 201310426346.3, 201310426677.7, 201310426729.0, 201210585811.3 and 201210553014.7 apply to the technology described. Document # 13-52-03 Rev C QST Corporation QST First Floor, Building No.2, Chengbei Road 235, Shanghai Tel: 86-21-69517300