Document Number: MMA685x Rev 4, 12/2011 **VRoHS** # **Single-Axis SPI Inertial Sensor** MMA685x is a SPI-based, single-axis, medium-g, over-damped lateral accelerometer designed for use in automotive airbag systems. #### **Features** - ±20g to ±120g full-scale range - 3.3V or 5V single supply operation - SPI-compatible serial interface - 10-bit digital signed or unsigned SPI data output - · Programmable arming functions - 12 low-pass filter options, ranging from 50 Hz to 1000 Hz - Optional offset cancellation with > 6s averaging period and < 0.25 LSB/s slew rate - Pb-Free 16-Pin QFN-6 by 6 Package #### **Referenced Documents** AECQ100, Revision G, dated May 14, 2007 (<a href="http://www.aecouncil.com/">http://www.aecouncil.com/</a>) | 0 | ORDERING INFORMATION | | | | | | | | | |--------------|----------------------|------------|-------------|--|--|--|--|--|--| | Device | Axis | Axis Range | Shipping | | | | | | | | MMA6851BKW | Х | ±25g | Tubes | | | | | | | | MMA6853BKW | Х | ±50g | Tubes | | | | | | | | MMA6855BKW | Х | ±120g | Tubes | | | | | | | | MMA6856BKW | Х | ±60g | Tubes | | | | | | | | MMA6851BKWR2 | Х | ±25g | Tape & Reel | | | | | | | | MMA6853BKWR2 | Х | ±50g | Tape & Reel | | | | | | | | MMA6855BKWR2 | Х | ±120g | Tape & Reel | | | | | | | | MMA6856BKWR2 | Х | ±60g | Tape & Reel | | | | | | | # **MMA685x** #### **Bottom View** 16 LEAD QFN 6 mm by 6 mm CASE 2086-01 # **Application Diagram** Figure 1. Application Diagram **Table 1. External Component Recommendations** | Ref Des | Туре | Description | Purpose | | | |---------|------------------------------------------|-----------------------------|---------------------------------------------------------|--|--| | C1 | C1 Ceramic 0.1 μF, 10%, 10V Minimum, X7R | | V <sub>CC</sub> Power Supply Decoupling | | | | C2 | Ceramic | 1 μF, 10%, 10V Minimum, X7R | Voltage Regulator Output Capacitor (C <sub>REG</sub> ) | | | | C3 | Ceramic | 1 μF, 10%, 10V Minimum, X7R | Voltage Regulator Output Capacitor (C <sub>REGA</sub> ) | | | # **Device Orientation** Figure 2. Device Orientation Diagram # **Internal Block Diagram** Figure 3. Block Diagram # 1 Pin Connections Figure 4. 16-Pin QFN Package, Top View #### **Table 2. Pin Description** | Pin | Pin<br>Name | Formal Name | Definition | |-----|--------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | V <sub>REGA</sub> | Analog<br>Supply | This pin is connected to the power supply for the internal analog circuitry. An external capacitor must be connected between this pin and $V_{SSA}$ . Reference Figure 1. | | 2 | V <sub>SS</sub> | Digital GND | This pin is the power supply return node for the digital circuitry. | | 3 | V <sub>REG</sub> | Digital<br>Supply | This pin is connected to the power supply for the internal digital circuitry. An external capacitor must be connected between this pin and $V_{SS}$ . Reference Figure 1. | | 4 | V <sub>SS</sub> | Digital GND | This pin is the power supply return node for the digital circuitry. | | 5 | N/C | No Connect | No Connection | | 6 | ARM/<br>PCM | Arm Output /<br>PCM Output | The function of this pin is configurable via the DEVCFG register as described in Section 3.1.6.5. When the arming output is selected, ARM can be configured as an open drain, active low output with a pullup current; or an open drain, active high output with a pulldown current. Alternatively, this pin can be configured as a digital output with a PCM signal proportional to the acceleration data. Reference Section 3.8.9 and Section 3.8.10. If unused, this pin must be left unconnected. | | 7 | TEST/<br>V <sub>PP</sub> | Programming<br>Voltage | This pin provides the power for factory programming of the OTP registers. This pin must be connected to $V_{SS}$ in the application. | | 8 | MISO | SPI Data Out | This pin functions as the serial data output for the SPI port. | | 9 | V <sub>CC</sub> | Supply | This pin supplies power to the device. An external capacitor must be connected between this pin and V <sub>SS</sub> . Reference Figure 1. | | 10 | SCLK | SPI Clock | This input pin provides the serial clock to the SPI port. An internal pulldown device is connected to this pin. | | 11 | MOSI | SPI Data In | This pin functions as the serial data input to the SPI port. An internal pulldown device is connected to this pin. | | 12 | CS | Chip Select | This input pin provides the chip select for the SPI port. An internal pullup device is connected to this pin. | | 13 | V <sub>SSA</sub> | Analog GND | This pin is the power supply return node for analog circuitry. | | 14 | N/C | No Connect | No Connection | | 15 | N/C | No Connect | No Connection | | 16 | V <sub>SSA</sub> | Analog GND | This pin is the power supply return node for analog circuitry. | | 17 | PAD | Die Attach<br>Pad | This pin is the die attach flag, and is internally connected to V <sub>SS</sub> . | | | Corner<br>Pads | Corner Pads | The corner pads are internally connected to V <sub>SS</sub> . | # MMA685x # **2 Electrical Characteristics** # 2.1 Maximum Ratings Maximum ratings are the extreme limits to which the device can be exposed without permanently damaging it. | # | Rating | Symbol | Value | Unit | | |----------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------|-------------------------------|-------------|-------------------| | 1 | Supply Voltage | V <sub>CC</sub> | -0.3 to +7.0 | V | (3) | | 2 | C <sub>REG</sub> , C <sub>REGA</sub> | V <sub>REG</sub> | -0.3 to +3.0 | V | (3) | | 3 | SCLK, $\overline{\text{CS}}$ , MOSI,V <sub>PP</sub> /TEST | V <sub>IN</sub> | -0.3 to V <sub>CC</sub> + 0.3 | V | (3) | | 4 | ARM | $V_{IN}$ -0.3 to $V_{CC}$ + 0.3 | | V | (3) | | 5 | SO (high impedance state) $V_{IN}$ -0.3 to $V_{CC}$ + 0.3 | | V | (3) | | | 6 | celeration without hitting internal g-cell stops $g_{gcell\_Clip}$ ±500 | | g | (3, 18) | | | 7 | Acceleration without saturation of internal circuitry \$\ g_{ADC_Clip}\$ | | ±375 | g | (3) | | 8 | Powered Shock (six sides, 0.5 ms duration) | 9 <sub>pms</sub> | ±1500 | g | (5, 18) | | 9 | Unpowered Shock (six sides, 0.5 ms duration) | g <sub>shock</sub> | ±2000 | g | (5, 18) | | 10 | Drop Shock (to concrete surface) | h <sub>DROP</sub> | 1.2 | m | (5) | | 11<br>12<br>13 | Electrostatic Discharge Human Body Model (HBM) Charge Device Model (CDM) Machine Model (MM) | V <sub>ESD</sub><br>V <sub>ESD</sub><br>V <sub>ESD</sub> | ±2000<br>±750<br>±200 | V<br>V<br>V | (5)<br>(5)<br>(5) | | 14 | Storage Temperature Range | T <sub>stg</sub> | -40 to +125 | °C | (5) | | 15 | Thermal Resistance - Junction to Case | q <sub>JC</sub> | 2.5 | °C/W | (14) | # 2.2 Operating Range The operating ratings are the limits normally expected in the application and define the range of operation. | # | Characteristic | Symbol | Min | Тур | Max | Units | | |----------|--------------------------------------------------------------------|-------------------|--------------------------|----------------------------------|-------------------------|-------|--------------| | 16<br>17 | 3 3 3 | Vcc | V <sub>L</sub><br>+3.135 | V <sub>TYP</sub><br>+3.3<br>+5.0 | V <sub>H</sub><br>+5.25 | V | (15)<br>(15) | | 18 | Operating Ambient Temperature Range<br>Verified by 100% Final Test | T <sub>A</sub> | T <sub>L</sub><br>-40 | _ | T <sub>H</sub><br>+105 | С | (1) | | 20 | Power-on Ramp Rate (V <sub>CC</sub> ) | V <sub>CC_r</sub> | 0.000033 | _ | 3300 | V/μs | (19) | # 2.3 Electrical Characteristics - Power Supply and I/O $V_L \leq (V_{CC} - V_{SS}) \leq V_H, \ T_L \leq T_A \leq T_H, \ |\Delta T_A| < 25 \ \text{K/min unless otherwise specified}$ | # | Characteristic | Symbol | Min | Тур | Max | Units | | |----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--------------------------------------------------------|--------------|-----------------------------------------------------------|------------------------------------|---------------------------------------------------------------------| | 21 | Supply Current * | I <sub>DD</sub> | 3.0 | _ | 7.0 | mA | (1) | | 22<br>23<br>24<br>25<br>26<br>27<br>28<br>29 | Power Supply Monitor Thresholds (See Figure 8) V <sub>CC</sub> Undervoltage (Falling) V <sub>REG</sub> Undervoltage (Falling) * V <sub>REG</sub> Overvoltage (Rising) V <sub>REGA</sub> Undervoltage (Falling) * * * * * * * * * * * * * | VCC_UV_f VREG_UV_f VREG_OV_r VREGA_UV_f VREGA_OV_r VHYST VHYST VHYST | 2.74<br>2.10<br>2.65<br>2.20<br>2.65<br>65<br>20<br>20 | | 3.02<br>2.25<br>2.85<br>2.35<br>2.85<br>110<br>210<br>150 | V<br>V<br>V<br>V<br>WV<br>mV<br>mV | (3, 6)<br>(3, 6)<br>(3, 6)<br>(3, 6)<br>(3, 6)<br>(3)<br>(3)<br>(3) | | 30<br>31<br>32 | Power Supply RESET Thresholds (See Figure 5, and Figure 8) V <sub>REG</sub> Undervoltage RESET (Falling) * V <sub>REG</sub> Undervoltage RESET (Rising) * V <sub>REG</sub> RESET Hysteresis | V <sub>REG_UVR_f</sub><br>V <sub>REG_UVR_r</sub><br>V <sub>HYST</sub> | 1.764<br>1.876<br>80 | | 2.024<br>2.152<br>140 | V<br>V<br>mV | (3, 6)<br>(3, 6)<br>(3) | | 33<br>34 | Internally Regulated Voltages VREG VREGA * | V <sub>REG</sub><br>V <sub>REGA</sub> | 2.42<br>2.42 | 2.50<br>2.50 | 2.58<br>2.58 | V | (1, 3)<br>(1, 3) | | 35<br>36 | External Filter Capacitor (C <sub>REG</sub> , C <sub>REGA</sub> ) Value ESR (including interconnect resistance) | C <sub>REG</sub><br>ESR | 700<br>— | 1000 | 1500<br>400 | nF<br>mΩ | (19)<br>(19) | | 37<br>38 | Power Supply Coupling 50 kHz $\leq$ f <sub>n</sub> $\leq$ 300 kHz 4 MHz $\leq$ f <sub>n</sub> $\leq$ 100 MHz | | _ | _ | 0.004<br>0.004 | LSB/mv<br>LSB/mv | (19)<br>(19) | | 39<br>40 | $ \begin{array}{ll} \text{Output High Voltage (MISO, PCM)} \\ 3.15 \text{V} \leq (\text{V}_{CC} \text{-} \text{V}_{SS}) \leq 3.45 \text{V (I}_{Load} = \text{-1 mA)} \\ 4.75 \text{V} \leq (\text{V}_{CC} \text{-} \text{V}_{SS}) \leq 5.25 \text{V (I}_{Load} = \text{-1 mA)} \\ \end{array} $ | V <sub>OH_3</sub><br>V <sub>OH_5</sub> | V <sub>CC</sub> - 0.2<br>V <sub>CC</sub> - 0.4 | _ | _ | V | (2, 3)<br>(2, 3) | | 41<br>42 | $ \begin{array}{ll} \text{Output Low Voltage (MISO PCM)} \\ 3.15 \text{V} \leq (\text{V}_{\text{CC}} - \text{V}_{\text{SS}}) \leq 3.45 \text{V (I}_{\text{Load}} = 1 \text{ mA)} \\ 4.75 \text{V} \leq (\text{V}_{\text{CC}} - \text{V}_{\text{SS}}) \leq 5.25 \text{V (I}_{\text{Load}} = 1 \text{ mA)} \\ \end{array} $ | V <sub>OL_3</sub><br>V <sub>OL_5</sub> | | | 0.2<br>0.4 | V | (2, 3)<br>(2, 3) | | | $ \begin{array}{ll} \mbox{Open Drain Output High Voltage (ARM)} \\ 3.15 \mbox{V} \leq (\mbox{V}_{CC} - \mbox{V}_{SS}) \leq 3.45 \mbox{V} (\mbox{I}_{ARM} = -1 \mbox{ mA)} \\ 4.75 \mbox{V} \leq (\mbox{V}_{CC} - \mbox{V}_{SS}) \leq 5.25 \mbox{V} (\mbox{I}_{ARM} = -1 \mbox{ mA)} \\ & * \\ \end{array} $ | V <sub>ODH_3</sub><br>V <sub>ODH_5</sub> | V <sub>CC</sub> - 0.2<br>V <sub>CC</sub> - 0.4 | _ | _ | V | (2, 3)<br>(2, 3) | | | $ \begin{array}{ll} \mbox{Open Drain Output Pulldown Current (ARM)} \\ 3.15 \mbox{V} \leq (\mbox{V}_{CC} - \mbox{V}_{SS}) \leq 3.45 \mbox{V} (\mbox{V}_{ARM} = 1.5 \mbox{ V}) \\ 4.75 \mbox{V} \leq (\mbox{V}_{CC} - \mbox{V}_{SS}) \leq 5.25 \mbox{V} (\mbox{V}_{ARM} = 1.5 \mbox{ V}) \end{array} $ | I <sub>ODPD_3</sub><br>I <sub>ODPD_5</sub> | 50<br>50 | | 100<br>100 | μA<br>μA | (2, 3)<br>(2, 3) | | 47<br>48 | $ \begin{array}{ll} \mbox{Open Drain Output Low Voltage (ARM)} \\ 3.15 \mbox{V} \leq (\mbox{V}_{CC} - \mbox{V}_{SS}) \leq 3.45 \mbox{V} (\mbox{I}_{ARM} = 1 \mbox{ mA)} \\ 4.75 \mbox{V} \leq (\mbox{V}_{CC} - \mbox{V}_{SS}) \leq 5.25 \mbox{V} (\mbox{I}_{ARM} = 1 \mbox{ mA)} \\ \end{array} \label{eq:controller} $ | V <sub>ODH_3</sub><br>V <sub>ODH_5</sub> | | _ | 0.2<br>0.4 | V | (2, 3)<br>(2, 3) | | | $ \begin{array}{ll} \mbox{Open Drain Output Pullup Current (ARM)} \\ 3.15 \mbox{V} \leq (\mbox{V}_{CC} - \mbox{V}_{SS}) \leq 3.45 \mbox{V} (\mbox{V}_{ARM} = 1.5 \mbox{ V}) \\ 4.75 \mbox{V} \leq (\mbox{V}_{CC} - \mbox{V}_{SS}) \leq 5.25 \mbox{V} (\mbox{V}_{ARM} = 1.5 \mbox{ V}) \end{array} $ | I <sub>ODPU_3</sub><br>I <sub>ODPU_5</sub> | -100<br>-100 | | -50<br>-50 | μA<br>μA | (2, 3)<br>(2, 3) | | 51 | Input High Voltage CS, SCLK, MOSI * | V <sub>IH</sub> | 2.0 | _ | _ | ٧ | (3, 6) | | | Input Low Voltage CS, SCLK, MOSI * | V <sub>IL</sub> | _ | _ | 1.0 | V | (3, 6) | | 53 | Input Voltage Hysteresis CS, SCLK, MOSI * | V <sub>I_HYST</sub> | 0.125 | _ | 0.500 | V | (19) | | 54<br>55 | $\begin{array}{c} \text{Input Current} \\ \text{High (at V}_{\text{IH}}) \ \underline{(SC} \text{LK, MOSI)} \\ \text{Low (at V}_{\text{IL}}) \ \overline{(CS)} \end{array} \qquad \qquad ^*$ | I <sub>IH</sub><br>I <sub>IL</sub> | -260<br>30 | -50<br>50 | -30<br>260 | μA<br>μA | (2, 3)<br>(2, 3) | # 2.4 Electrical Characteristics - Sensor and Signal Chain $V_L \leq (V_{CC} - V_{SS}) \leq V_H, \ T_L \leq T_A \leq T_H, \ |\Delta T_A| < 25 \ \text{K/min unless otherwise specified}$ | # | Characteristic | Symbol | Min | Тур | Max | Units | | |----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------|-------------------------------------------------------|----------------------------------|--------------------------------------| | 56<br>57<br>58<br>59 | Digital Sensitivity (SPI, 10-Bit Output) 25g (MMA6851) | SENS<br>SENS<br>SENS<br>SENS | _<br>_<br>_ | 20.479<br>9.766<br>8.192<br>4.096 | _<br>_<br>_ | LSB/g<br>LSB/g<br>LSB/g<br>LSB/g | (1, 9)<br>(1, 9)<br>(1, 9)<br>(1, 9) | | 60<br>61<br>67 | $\label{eq:sensitivity} \begin{array}{ll} \text{Sensitivity Error} & \text{$T_A=25^{\circ}$C}\\ -40^{\circ}\text{$C\leq T_A\leq 105^{\circ}$C}\\ -40^{\circ}\text{$C\leq T_A\leq 105^{\circ}$C,$V$_{CC\_UV\_f}\leq V_{CC}$-$V$_{SS}\leq V_L} \end{array}$ | ΔSENS<br>ΔSENS<br>ΔSENS | -4<br>-5<br>-5 | _<br>_<br>_ | +4<br>+5<br>+5 | %<br>%<br>% | (1)<br>(1)<br>(3) | | 68<br>69<br>70<br>71 | $ \begin{array}{ll} \mbox{Offset at 0g (No Offset Cancellation)} \\ \mbox{10-Bits, unsigned} & * \\ \mbox{10-Bits, signed} & * \\ \mbox{10-Bits, unsigned, $V_{CC\_UV\_f} \le V_{CC} - V_{SS} \le V_L$} \\ \mbox{10-Bits, signed, $V_{CC\_UV\_f} \le V_{CC} - V_{SS} \le V_L$} \end{array} $ | OFFSET<br>OFFSET<br>OFFSET<br>OFFSET | 452<br>-60<br>452<br>-60 | 512<br>0<br>512<br>0 | 572<br>+60<br>572<br>+60 | LSB<br>LSB<br>LSB<br>LSB | (1)<br>(1)<br>(3)<br>(3) | | 72<br>73 | Offset Monitor Thresholds Positive Threshold (10-Bits, unsigned) Negative Threshold (10-Bits, unsigned) | OFFTHR <sub>POS</sub><br>OFFTHR <sub>NEG</sub> | | 612<br>412 | | LSB<br>LSB | (7)<br>(7) | | 74<br>75<br>76<br>77 | Range of Output (SPI, 10-Bits, unsigned) Normal Fault Response Code Unused Codes Unused Codes | RANGE<br>FAULT<br>UNUSED<br>UNUSED | 32<br>—<br>1<br>993 | | 992<br>—<br>31<br>1023 | LSB<br>LSB<br>LSB<br>LSB | (7)<br>(7)<br>(7)<br>(7) | | 78<br>79<br>80<br>81 | Range of Output (SPI, 10-Bits, signed) Normal Fault Response Code Unused Codes Unused Codes | RANGE<br>FAULT<br>UNUSED<br>UNUSED | -480<br>—<br>-511<br>481 | <br>-512<br><br> | 480<br>—<br>-481<br>511 | LSB<br>LSB<br>LSB<br>LSB | (7)<br>(7)<br>(7)<br>(7) | | 82 | Nonlinearity * | NL <sub>OUT</sub> | -1 | _ | 1 | % FSR | (3) | | 83<br>84 | System Output Noise<br>RMS (10-Bit, All Ranges, 400 Hz, 4-pole LPF)<br>Peak to Peak (10-Bit, All Ranges, 400 Hz, 4-pole LPF) | n <sub>RMS</sub><br>n <sub>P-P</sub> | _ | | 0.5<br>1.0 | LSB<br>LSB | (3)<br>(3) | | 85<br>86 | Cross-Axis Sensitivity VZX VYX * | $V_{ZX} \ V_{YX}$ | -4<br>-4 | _<br>_ | +4<br>+4 | %<br>% | (3)<br>(3) | | 87<br>88<br>89<br>90 | | $\Delta \mathrm{ST_{Low25}}$ $\Delta \mathrm{ST_{Low}}$ $\Delta \mathrm{ST_{HI25}}$ $\Delta \mathrm{ST_{HI}}$ | ΔST <sub>MIN</sub><br>11.25<br>10.68<br>22.5<br>21.37 | ΔST <sub>NOM</sub> 15 15 30 30 | AST <sub>MAX</sub><br>18.75<br>19.69<br>37.5<br>39.38 | g<br>g<br>g | (1)<br>(1)<br>(1)<br>(1) | | 92 | V <sub>CC_UV_f</sub> ≤ V <sub>CC</sub> - V <sub>SS</sub> ≤ V <sub>L</sub><br>STMAG = 1, -40°C ≤ T <sub>A</sub> ≤ 105°C<br>V <sub>CC_UV_f</sub> ≤ V <sub>CC</sub> - V <sub>SS</sub> ≤ V <sub>L</sub> | ΔST <sub>Low</sub><br>ΔST <sub>HI</sub> | 10.68<br>21.37 | 15<br>30 | 19.69<br>39.38 | g<br>g | (3) | | 93 | Acceleration (without hitting internal g-cell stops) Any Range Positive/Negative | g <sub>g-cell_Clip</sub> | 500 | 560 | 600 | g | (19) | # 2.5 Dynamic Electrical Characteristics - Signal Chain $V_L \leq (V_{CC} - V_{SS}) \leq V_H, \ T_L \leq T_A \leq T_H, \ |\Delta T_A| < 25 \ \text{K/min unless otherwise specified}$ | # | Characteristic | Symbol | Min | Тур | Max | Units | | |-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------------------------------------------------|-------------------------------------------|----------------------------------------------|-------------------------------------------------------------------| | 94<br>95<br>96 | DSP Sample Rate (LPF 0,1,2,3,4,5) DSP Sample Rate (LPF 8,9,10,11,12,13) Interpolation Sample Rate | t <sub>S</sub><br>t <sub>S</sub><br>t <sub>INTERP</sub> | | 64/f <sub>OSC</sub><br>128/f <sub>OSC</sub><br>t <sub>S</sub> /2 | | s<br>s<br>s | (7)<br>(7)<br>(7) | | 97<br>98 | Datapath Latency (excluding g-cell and Low Pass Filter) $ T_S = 64/f_{OSC} \qquad \qquad ^* \\ T_S = 128/f_{OSC} \qquad \qquad ^* $ | <sup>t</sup> DataPath_8<br><sup>t</sup> DataPath_16 | 33.0<br>51.9 | 34.8<br>54.6 | 36.5<br>57.4 | μs<br>μs | (7, 16)<br>(7, 16) | | 99<br>100<br>101<br>102<br>103<br>104 | $ \begin{array}{llllllllllllllllllllllllllllllllllll$ | fCO(LPF)<br>fC1(LPF)<br>fC2(LPF)<br>fC3(LPF)<br>fC4(LPF)<br>fC5(LPF) | 95<br>285<br>380<br>760<br>950<br>380 | 100<br>300<br>400<br>800<br>1000<br>400 | 105<br>315<br>420<br>840<br>1050<br>420 | Hz<br>Hz<br>Hz<br>Hz<br>Hz<br>Hz | (3, 7, 17)<br>(7, 17)<br>(7, 17)<br>(7, 17)<br>(7, 17)<br>(7, 17) | | 105<br>106<br>107<br>108<br>109<br>110 | | f <sub>C8(LPF)</sub> f <sub>C9(LPF)</sub> f <sub>C10(LPF)</sub> f <sub>C11(LPF)</sub> f <sub>C12(LPF)</sub> f <sub>C13(LPF)</sub> | 47.5<br>142.5<br>190<br>380<br>475<br>190 | 50<br>150<br>200<br>400<br>500<br>200 | 52.5<br>157.5<br>210<br>420<br>525<br>210 | Hz<br>Hz<br>Hz<br>Hz<br>Hz<br>Hz | (7, 17)<br>(7, 17)<br>(7, 17)<br>(7, 17)<br>(7, 17)<br>(7, 17) | | 111<br>112<br>113<br>114<br>115<br>116<br>117 | Offset Cancellation (Normal Mode, 10-Bit Output) Offset Averaging Period Offset Slew Rate Offset Update Rate Offset Correction Value per Update Positive Offset Correction Threshold Positive Offset Correction Threshold Negative **Offset Correction Threshold Negative** **Offset Correction Threshold Negative** **Offset Correction Threshold Negative** **Offset Correction Threshold Negative** | OFF <sub>AVEPER</sub> OFF <sub>SLEW</sub> OFF <sub>RATE</sub> OFF <sub>CORRP</sub> OFF <sub>CORRN</sub> OFF <sub>THP</sub> OFF <sub>THN</sub> | | 6.291456<br>0.2384<br>1049<br>0.25<br>-0.25<br>0.125<br>0.125 | | s<br>LSB/s<br>ms<br>LSB<br>LSB<br>LSB<br>LSB | (7)<br>(7)<br>(7)<br>(7)<br>(7)<br>(7)<br>(7) | | 118 | Offset Monitor Bypass Time after Self-Test Deactivation | t <sub>ST_OMB</sub> | _ | 320 | _ | t <sub>S</sub> | (3, 7) | | 119 | Time Between Acceleration Data Requests | t <sub>ACC_REQ</sub> | 15 | _ | _ | μs | (3, 7, 20) | | 120<br>121<br>122 | Arming Output Activation Time (ARM, I <sub>ARM</sub> = 200 μA) Moving Average and Count Arming Modes (2,3,4,5) Unfiltered Mode Activation Delay (Reference Figure 28) Unfiltered Mode Arm Assertion Time (Reference Figure 28) | t <sub>ARM</sub> t <sub>ARM_UF_DLY</sub> t <sub>ARM_UF_ASSERT</sub> | 0<br>0<br>5.00 | _<br> | 1.05<br>1.05<br>6.579 | μs<br>μs<br>μs | (3, 12)<br>(3, 12)<br>(3) | | 123 | Sensing Element Natural Frequency (-40°C ≤ T <sub>A</sub> ≤ 105°C) | f <sub>gcell</sub> | 10791 | _ | 15879 | Hz | (19) | | 124 | Sensing Element Cutoff Frequency (-3 dB ref. to 0 Hz, -40°C $\leq$ T <sub>A</sub> $\leq$ 105°C) | f <sub>gcell</sub> | 0.851 | _ | 2.29 | kHz | (19) | | 125 | Sensing Element Damping Ratio (-40°C ≤ T <sub>A</sub> ≤ 105°C) | ζ <sub>gcell</sub> | 2.46 | _ | 9.36 | _ | (19) | | 126 | Sensing Element Delay (@100 Hz, -40°C $\leq$ T <sub>A</sub> $\leq$ 105°C) | f <sub>gcell_delay</sub> | 70 | _ | 187 | μs | (19) | | 127 | Package Resonance Frequency | f <sub>Package</sub> | 100 | _ | _ | kHz | (19) | | 128 | Package Quality Factor | q <sub>Package</sub> | 1 | _ | 5 | | (19) | # 2.6 Dynamic Electrical Characteristics - Supply and SPI $V_L \le (V_{CC} - V_{SS}) \le V_H$ , $T_L \le T_A \le T_H$ , $|\Delta T_A| < 25$ K/min unless otherwise specified | # | Characteristic | | Symbol | Min | Тур | Max | Units | | |-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------|--------|-------------|------------------------------------------|-------------------------------------------------------------------------------------------------| | | Power-On Recovery Time (VCC = VCCMIN to first SPI access) Power-On Recovery Time (Internal POR to first SPI access) | | t <sub>OP</sub><br>t <sub>OP</sub> | _ | _ | 10<br>840 | ms<br>μs | (3)<br>(3, 7) | | 131<br>132 | Internal Oscillator Frequency Test Frequency - Divided from Internal Oscillator | * | f <sub>OSC</sub><br>f <sub>OSCTST</sub> | 7.6<br>0.95 | 8<br>1 | 8.4<br>1.05 | MHz<br>MHz | (7)<br>(1) | | 133<br>134<br>135<br>136<br>137<br>138<br>139<br>140<br>141<br>142<br>143<br>144<br>145<br>146<br>147 | Clock (SCLK) high time (90% of $V_{CC}$ to 90% of $V_{CC}$ ) Clock (SCLK) low time (10% of $V_{CC}$ to 10% of $V_{CC}$ ) Clock (SCLK) rise time (10% of $V_{CC}$ to 90% of $V_{CC}$ ) Clock (SCLK) fall time (90% of $V_{CC}$ to 10% of $V_{CC}$ ) $\overline{CS}$ asserted to SCLK high ( $\overline{CS}$ = 10% of $V_{CC}$ to SCLK = 10% of $V_{CC}$ ) CS asserted to MISO valid ( $\overline{CS}$ = 10% of $V_{CC}$ to MISO = 10/90% of $V_{CC}$ ) Data setup time (MOSI = 10/90% of $V_{CC}$ to MCSI = 10% of $V_{CC}$ ) MOSI Data hold time (SCLK = 90% of $V_{CC}$ to MISO = 10/90% of $V_{CC}$ ) MISO Data hold time (SCLK = 90% of $V_{CC}$ to MISO = 10/90% of $V_{CC}$ ) SCLK low to data valid (SCLK = 10% of $V_{CC}$ to $\overline{CS}$ = 90% of $V_{CC}$ ) SCLK low to $\overline{CS}$ high (SCLK = 10% of $V_{CC}$ to $\overline{CS}$ = 90% of $V_{CC}$ ) $\overline{CS}$ high to $\overline{CS}$ low ( $\overline{CS}$ = 90% of $V_{CC}$ to $\overline{CS}$ = 90% of $V_{CC}$ ) SCLK low to $\overline{CS}$ low ( $\overline{CS}$ = 90% of $V_{CC}$ to $\overline{CS}$ = 90% of $V_{CC}$ ) SCLK low to $\overline{CS}$ low ( $\overline{CS}$ = 90% of $V_{CC}$ to $\overline{CS}$ = 90% of $V_{CC}$ ) | * * * * * * * * * * * | tsclk tsclkh tsclkl tsclkr tsclkr tsclkr tlead taccess tsetup thold_out tvalid tlag tdsable tcsn tcsclk | 120<br>40<br>40<br>——————————————————————————————— | | | ns n | (3)<br>(3)<br>(19)<br>(19)<br>(3)<br>(3)<br>(3)<br>(3)<br>(3)<br>(3)<br>(3)<br>(3)<br>(3)<br>(3 | - 1. Parameters tested 100% at final test. - 2. Parameters tested 100% at wafer probe. - 3. Parameters verified by characterization - 4. (\*) Indicates a critical characteristic. - Verified by qualification testing. - 6. Parameters verified by pass/fail testing in production. - Functionality guaranteed by modeling, simulation and/or design verification. Circuit integrity assured through IDDQ and scan testing. Timing is determined by internal system clock frequency. - 8. N/A - 9. Devices are trimmed at 100 Hz with 1000 Hz low-pass filter option selected. Response is corrected to 0 Hz response. - 10. Low-pass filter cutoff frequencies shown are -3dB referenced to 0 Hz response. - 11. Power supply ripple at frequencies greater than 900 kHz should be minimized to the greatest extent possible. - 12. Time from falling edge of $\overline{\text{CS}}$ to ARM output valid. - 13. N/A - 14. Thermal resistance between the die junction and the exposed pad; cold plate is attached to the exposed pad. - 15. Device characterized at all values of V<sub>L</sub> and V<sub>H</sub>. Production test is conducted at all typical voltages (V<sub>TYP</sub>) unless otherwise noted. - 16. Data path Latency is the signal latency from g-cell to SPI output disregarding filter group delays. - 17. Filter characteristics are specified independently, and do not include g-cell frequency response. - 18. Electrostatic Deflection Test completed during wafer probe. - 19. Verified by simulation. - 20. Acceleration Data Request timing constraint only applies for proper operation of the Arming Function. Figure 5. Power-Up Timing Figure 6. Serial Interface Timing # 3 Functional Description # 3.1 Customer Accessible Data Array A customer accessible data array allows for each device to be customized. The array consists of an OTP factory programmable block and read/write registers for device programmability and status. The OTP and writable register blocks incorporate independent CRC circuitry for fault detection (reference Section 3.2). The writable register block includes a locking mechanism to prevent unintended changes during normal operation. Portions of the array are reserved for factory-programmed trim values. The customer accessible data is shown in Table 3. **Table 3. Customer Accessible Data** | | Location Bit Function | | | | | | | | | Туре | |------|-----------------------|--------------|--------------|--------------|-----------------------|--------------|--------------|--------------|--------------|-------| | Addr | Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Type | | \$00 | SN0 | SN[7] | SN[6] | SN[5] | SN[4] | SN[3] | SN[2] | SN[1] | SN[0] | | | \$01 | SN1 | SN[15] | SN[14] | SN[13] | SN[12] | SN[11] | SN[10] | SN[9] | SN[8] | | | \$02 | SN2 | SN[23] | SN[22] | SN[21] | SN[20] | SN[19] | SN[18] | SN[17] | SN[16] | | | \$03 | SN3 | SN[31] | SN[30] | SN[29] | SN[28] | SN[27] | SN[26] | SN[25] | SN[24] | | | \$04 | Reserved F | | \$05 | Reserved ĺ | | \$06 | FCTCFG | STMAG | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | \$07 | | | | Invalid Add | lress: "Invalid Regis | ter Request" | | | | | | \$08 | PN | PN[7] | PN[6] | PN[5] | PN[4] | PN[3] | PN[2] | PN[1] | PN[0] | | | \$09 | | | | Invalid Add | lress: "Invalid Regis | ter Request" | | | | | | \$0A | DEVCTL | RES_1 | RES_0 | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | | | \$0B | DEVCFG | Reserved | Reserved | ENDINIT | SD | OFMON | A_CFG[2] | A_CFG[1] | A_CFG[0] | ĺ | | \$0C | DEVCFG_X | ST | Reserved | Reserved | Reserved | LPF[3] | LPF[2] | LPF[1] | LPF[0] | | | \$0D | | | | Invalid Add | lress: "Invalid Regis | ter Request" | | | | ĺ | | \$0E | ARMCFG | Reserved | Reserved | APS[1] | APS[0] | AWS_N[1] | AWS_N[0] | AWS_P[1] | AWS_P[0] | R/W | | \$0F | | | | Invalid Add | lress: "Invalid Regis | ter Request" | | | | 10,00 | | \$10 | ARMT_P | AT_P[7] | AT_P[6] | AT_P[5] | AT_P[4] | AT_P[3] | AT_P[2] | AT_P[1] | AT_P[0] | | | \$11 | | | | Invalid Add | lress: "Invalid Regis | ter Request" | | | | ĺ | | \$12 | ARMT_N | AT_N[7] | AT_N[6] | AT_N[5] | AT_N[4] | AT_N[3] | AT_N[2] | AT_N[1] | AT_N[0] | | | \$13 | | | | Invalid Add | lress: "Invalid Regis | ter Request" | | | | | | \$14 | DEVSTAT | UNUSED | IDE | SDOV | DEVINIT | MISOERR | 0 | OFFSET | DEVRES | | | \$15 | COUNT | COUNT[7] | COUNT[6] | COUNT[5] | COUNT[4] | COUNT[3] | COUNT[2] | COUNT[1] | COUNT[0] | | | \$16 | OFFCORR_X | OFFCORR_X[7] | OFFCORR_X[6] | OFFCORR_X[5] | OFFCORR_X[4] | OFFCORR_X[3] | OFFCORR_X[2] | OFFCORR_X[1] | OFFCORR_X[0] | R | | \$17 | | | | Invalid Add | lress: "Invalid Regis | ter Request" | | | | | | \$1C | Reserved | | \$1D | Reserved | Type codes F: Factory programmed OTP location R/W: Read/write register R: Read-only register N/A: Not applicable # 3.1.1 Device Serial Number Registers A unique serial number is programmed into the serial number registers of each MMA685x device during manufacturing. The serial number is composed of the following information: | Bit Range | Content | |-----------|---------------| | S12 - S0 | Serial Number | | S31 - S13 | Lot Number | Serial numbers begin at 1 for all produced devices in each lot, and are sequentially assigned. Lot numbers begin at 1 and are sequentially assigned. No lot will contain more devices than can be uniquely identified by the 13-bit serial number. Depending on lot size and quantities, all possible lot numbers and serial numbers may not be assigned. The serial number registers are included in the OTP shadow register array CRC verification. Reference Section 3.2.1 for details regarding the CRC verification. Beyond this, the contents of the serial number registers have no impact on device operation or performance, and are only used for traceability purposes. #### 3.1.2 Reserved Registers These reserved registers are read-only and have no impact on device operation or performance. **Table 4. Reserved Registers** | Loca | ation | Bit | | | | | | | | | |---------|----------|----------|----------|----------|----------|----------|----------|----------|----------|--| | Address | Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | \$04 | Reserved | | \$05 | Reserved | # 3.1.3 Factory Configuration Registers The factory configuration register is a one time programmable, read only register which contains customer specific device configuration information that is programmed by Freescale. **Table 5. Factory Configuration Register** | Loca | ation | Bit | | | | | | | | |---------|----------|-------|-----------------|---|---|---|---|---|---| | Address | Register | 7 | 7 6 5 4 3 2 1 0 | | | | | | 0 | | \$06 | FCTCFG | STMAG | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### 3.1.3.1 Self-Test Magnitude Selection Bits (STMAG) The self-test magnitude selection bits indicate if the nominal self-test deflection value is set to the low or high value as shown in the table below. | STMAG | Full-Scale<br>Acceleration Range | Nominal Self-Test Deflection Value<br>(Reference Section 2.4) | |-------|----------------------------------|---------------------------------------------------------------| | 0 | ≤ 60g | $\Delta ST_Low$ | | 1 | > 60g | ΔST <sub>HI</sub> | # 3.1.4 Part Number Register (PN) The part number register is a one time programmable, read only register which contains two digits of the device part number to identify the axis and range information. The contents of this register have no impact on device operation or performance. **Table 6. Part Number Register** | Loca | ation | | Bit | | | | | | | |---------|----------|-------|-------------------------------------------|--|--|--|--|--|-------| | Address | Register | 7 | 7 6 5 4 3 2 1 0 | | | | | | | | \$08 | PN | PN[7] | PN[7] PN[6] PN[5] PN[4] PN[3] PN[2] PN[1] | | | | | | PN[0] | | PN Regi | ster Value | Range | |---------|------------|-----------------------| | Decimal | HEX | Reference Section 2.4 | | 51 | \$33 | 20 | | 52 | \$34 | 35 | | 53 | \$35 | 50 | | 54 | \$36 | 75 | | 55 | \$37 | 100 | | 56 | \$38 | 60 | # 3.1.5 Device Control Register (DEVCTL) The device control register is a read-write register which contains device control operations that can be applied during both initialization and normal operation. **Table 7. Device Control Register** | Loca | ation | Bit | | | | | | | | |---------|----------|-------|-------------------------------------------------------------------|---|---|---|---|---|----------| | Address | Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | \$0A | DEVCTL | RES_1 | RES_1 RES_0 Reserved Reserved Reserved Reserved Reserved Reserved | | | | | | Reserved | | Reset | Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # 3.1.5.1 Reset Control (RES\_1, RES\_0) A series of three consecutive register write operations to the reset control bits in the DEVCTL register will cause a device reset. To reset the internal digital circuitry, the following register write operations must be performed in the order shown below. The register write operations must be consecutive SPI commands in the order shown or the device will not be reset. | Register Write to DEVCTL | RES_1 | RES_0 | Effect | |--------------------------|-------|-------|--------------| | SPI Register Write 1 | 0 | 0 | No Effect | | SPI Register Write 2 | 1 | 1 | No Effect | | SPI Register Write 3 | 0 | 1 | Device RESET | The response to the Register Write returns '0' for RES\_1 and RES\_0. A Register Read of RES\_1 and RES\_0 returns '0' and terminates the reset sequence. #### 3.1.5.2 Reserved Bits (DEVCTL[5:0]) Bits 5 through 0 of the DEVCTL register are reserved. A write to the reserved bits must always be logic '0' for normal device operation and performance. # 3.1.6 Device Configuration Register (DEVCFG) The device configuration register is a read/write register which contains data for general device configuration. The register can be written during initialization but is locked once the ENDINIT bit is set. This register is included in the writable register CRC check. Refer to Section 3.2.2 for details. **Table 8. Device Configuration Register** | Loca | ation | Bit | | | | | | | | |-------------|----------|----------|---------------------------------------------------------------|---|---|---|---|---|----------| | Address | Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | \$0B | DEVCFG | Reserved | Reserved Reserved ENDINIT SD OFMON A_CFG[2] A_CFG[1] A_CFG[1] | | | | | | A_CFG[0] | | Reset Value | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### 3.1.6.1 Reserved Bits (Reserved) Bits 6 and 7 of the DEVCFG register are reserved. A write to the reserved bits must always be logic '0' for normal device operation and performance. #### 3.1.6.2 End of Initialization Bit (ENDINIT) The ENDINIT bit is a control bit used to indicate that the user has completed all device and system level initialization tests, and that MMA685x will operate in normal mode. Once the ENDINIT bit is set, writes to all writable register bits are inhibited except for the DEVCTL register. Once written, the ENDINIT bit can only be cleared by a device reset. The writable register CRC check (reference Section 3.2.2) is only enabled when the ENDINIT bit is set. ### 3.1.6.3 SD Bit The $\overline{SD}$ bit determines the format of acceleration data results. If the $\overline{SD}$ bit is set to a logic '1', unsigned results are transmitted, with the zero-g level represented by a nominal value of 512. If the $\overline{SD}$ bit is cleared, signed results are transmitted, with the zero-g level represented by a nominal value of 0. | SD | Operating Mode | |----|----------------------| | 1 | Unsigned Data Output | | 0 | Signed Data Output | #### 3.1.6.4 OFMON Bit The OFMON bit determines if the offset monitor circuit is enabled. If the OFMON bit is set to a logic '1', the offset monitor is enabled. Refer to Section 3.8.5 for more information. If the OFMON bit is cleared, the offset monitor is disabled. | OFMON | Operating Mode | |-------|---------------------------------| | 1 | Offset Monitor Circuit Enabled | | 0 | Offset Monitor Circuit Disabled | #### 3.1.6.5 ARM Configuration Bits (A\_CFG[2:0]) The ARM Configuration Bits (A\_CFG[2:0]) select the mode of operation for the ARM/PCM pins. **Table 9. Arming Output Configuration** | A_CFG[2] | A_CFG[1] | A-CFG[0] | Operating Mode | Output Type | Reference | |----------|----------|----------|---------------------|-----------------------------------|-----------------| | 0 | 0 | 0 | Arm Output Disabled | Hi Impedance | | | 0 | 0 | 1 | PCM Output | Digital Output | Section 3.8.10 | | 0 | 1 | 0 | Moving Average Mode | Active High with Pulldown Current | Section 3.8.9.1 | | 0 | 1 | 1 | Moving Average Mode | Active Low with Pullup Current | Section 3.8.9.1 | | 1 | 0 | 0 | Count Mode | Active High with Pulldown Current | Section 3.8.9.2 | | 1 | 0 | 1 | Count Mode | Active Low with Pullup Current | Section 3.8.9.2 | | 1 | 1 | 0 | Unfiltered Mode | Active High with Pulldown Current | Section 3.8.9.3 | | 1 | 1 | 1 | Unfiltered Mode | Active Low with Pullup Current | Section 3.8.9.3 | #### 3.1.7 Axis Configuration Register (DEVCFG\_X) The Axis configuration register is a read/write register which contains axis specific configuration information. This register can be written during initialization, but is locked once the ENDINIT bit is set. This register is included in the writable register CRC check. Refer to Section 3.2.2 for details **Table 10. Axis Configuration Registers** | Location Bit | | | | | | | | | | |--------------|----------|----|----------|----------|----------|--------|--------|--------|--------| | Address | Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | \$0C | DEVCFG_X | ST | Reserved | Reserved | Reserved | LPF[3] | LPF[2] | LPF[1] | LPF[0] | | Reset Value | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### 3.1.7.1 Self-Test Control (ST) The ST bit enables and disables the self-test circuitry. Self-test circuitry is enabled if a logic '1' is written to ST and the ENDINIT bit has not been set. Enabling the self-test circuitry results in a positive acceleration value. Self-test deflection values are specified in Section 2.4. ST is always cleared following internal reset. When the self-test circuitry is active, the offset cancellation block and the offset monitor status are suspended, and the status bits in the Acceleration Data Request Response will indicate "Self-Test Active". Reference Section 3.8.4 and Section 4.2 for details. When the self-test circuitry is disabled by clearing the ST bit, the offset monitor remains disabled until the time $t_{ST\_OMB}$ specified in Section 2.4 expires. However, the status bits in the Acceleration Data Request Response will immediately indicate that self-test has been deactivated. #### 3.1.7.2 Reserved Bits (Reserved) Bits 6 through 4 of the DEVCFG\_X register are reserved. A write to the reserved bits must always be logic '0' for normal device operation and performance. # 3.1.7.3 Low-Pass Filter Selection Bits (LPF[3:0]) The Low Pass Filter selection bit selects a low-pass filter as shown in Table 11. Refer to Section 3.8.3 for details regarding filter configurations. **Table 11. Low Pass Filter Selection Bits** | LPF[3] | LPF[2] | LPF[1] | LPF[0] | Low Pass Filter Selected | Nominal Sample Rate (μs) | |--------|--------|--------|--------|--------------------------|--------------------------| | 0 | 0 | 0 | 0 | 100 Hz, 4-pole | 8 | | 0 | 0 | 0 | 1 | 300 Hz, 4-Pole | 8 | | 0 | 0 | 1 | 0 | 400 Hz, 4-Pole | 8 | | 0 | 0 | 1 | 1 | 800 Hz, 4-Pole | 8 | | 0 | 1 | 0 | 0 | 1000 Hz, 4-Pole | 8 | | 0 | 1 | 0 | 1 | 400 Hz, 3-Pole | 8 | | 0 | 1 | 1 | 0 | Reserved | Reserved | | 0 | 1 | 1 | 1 | Reserved | Reserved | | 1 | 0 | 0 | 0 | 50 Hz, 4-Pole | 16 | | 1 | 0 | 0 | 1 | 150 Hz, 4-Pole | 16 | | 1 | 0 | 1 | 0 | 200 Hz, 4-Pole | 16 | | 1 | 0 | 1 | 1 | 400 Hz, 4-Pole | 16 | | 1 | 1 | 0 | 0 | 500 Hz, 4-Pole | 16 | | 1 | 1 | 0 | 1 | 200 Hz, 3-Pole | 16 | | 1 | 1 | 1 | 0 | Reserved | Reserved | | 1 | 1 | 1 | 1 | Reserved | Reserved | Note: Filter characteristics do not include g-cell frequency response. # 3.1.8 Arming Configuration Registers (ARMCFG) The arming configuration register contains configuration information for the arming function. The values in this register are only relevant if the arming function is operating in moving average mode, or count mode. This register can be written during initialization but is locked once the ENDINIT bit is set. Refer to Section 3.1.6.2. This register is included in the writable register CRC check. Refer to Section 3.2.2 for details. **Table 12. Arming Configuration Register** | Loca | ation | Bit | | | | | | | | | |---------|----------|----------|----------|--------|--------|----------|----------|----------|----------|--| | Address | Register | 7 | 7 6 5 | | 4 | 3 | 2 | 1 | 0 | | | \$0E | ARMCFG | Reserved | Reserved | APS[1] | APS[0] | AWS_N[1] | AWS_N[0] | AWS_P[1] | AWS_P[0] | | | Reset | Value | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | # 3.1.8.1 Reserved Bits (Reserved) Bits 7 through 6 of the ARMCFG register are reserved. A write to the reserved bits must always be logic '0' for normal device operation and performance. # 3.1.8.2 Arming Pulse Stretch (APS[1:0]) The APS[1:0] bit sets the programmable pulse stretch time for the arming outputs. Refer to Section 3.8.9 for more details regarding the arming function. **Table 13. Arming Pulse Stretch Definitions** | APS[1] | APS[0] Pulse Stretch Time <sup>(1)</sup> (Typical Oscillator) | | | | |--------|---------------------------------------------------------------|-------------------------|--|--| | 0 | 0 | 0 mS | | | | 0 | 1 | 16.256 ms - 16.384 ms | | | | 1 | 0 | 65.408 ms - 65.536 ms | | | | 1 | 1 | 261.888 ms - 262.016 ms | | | <sup>1.</sup> Pulse stretch times are derived from the internal oscillator, so the tolerance on this oscillator applies. #### 3.1.8.3 Arming Window Size (AWS\_x[1:0]) The AWS\_x[1:0] bit has a different function depending on the state of the A\_CFG bits in the DEVCFG register. If the arming function is set to moving average mode, the AWS bits set the number of acceleration samples used for the arming function moving average. The number of samples is set independently for polarity. If the arming function is set to count mode, the AWS bits set the sample count limit for the arming function. The sample count limit is set independently. Refer to Section 3.8.9 for more details regarding the arming function. Table 14. Positive Arming Window Size Definitions (Moving Average Mode) | AWS_P[1] | AWS_P[0] | Positive Window Size | |----------|----------|----------------------| | 0 | 0 | 2 | | 0 | 1 | 4 | | 1 | 0 | 8 | | 1 | 1 | 16 | Table 15. Negative Arming Window Size Definitions (Moving Average Mode) | AWS_N[1] | AWS_N[0] | Negative Window Size | |----------|----------|----------------------| | 0 | 0 | 2 | | 0 | 1 | 4 | | 1 | 0 | 8 | | 1 | 1 | 16 | **Table 16. Arming Count Limit Definitions (Count Mode)** | AWS_N[1] | AWS_N[0] | AWS_P[1] | AWS_P[0] | Sample Count Limit | |------------|------------|----------|----------|--------------------| | Don't Care | Don't Care | 0 | 0 | 1 | | Don't Care | Don't Care | 0 | 1 | 3 | | Don't Care | Don't Care | 1 | 0 | 7 | | Don't Care | Don't Care | 1 | 1 | 15 | #### 3.1.9 Arming Threshold Registers (ARMT\_P, ARMT\_N) These registers contain the positive and negative thresholds to be used by the arming function. Refer to Section 3.8.9 for more details regarding the arming function. These registers can be written during initialization but are locked once the ENDINIT bit is set. Refer to Section 3.1.6.2. These registers are included in the writable register CRC check. Refer to Section 3.2.2 for details. **Table 17. Arming Threshold Registers** | Loca | ation | Bit | | | | | | | | |---------|-------------------------------------|---------|---------|---------|---------|---------|---------|---------|---------| | Address | Register | 7 | 6 5 | | 4 | 3 | 2 | 1 | 0 | | \$10 | ARMT_P | AT_P[7] | AT_P[6] | AT_P[5] | AT_P[4] | AT_P[3] | AT_P[2] | AT_P[1] | AT_P[0] | | \$12 | \$12 ARMT_N AT_N[7] AT_N[6] AT_N[5] | | AT_N[4] | AT_N[3] | AT_N[2] | AT_N[1] | AT_N[0] | | | | Reset | Reset Value 0 0 0 0 0 0 0 | | | | 0 | | | | | The values programmed into the threshold registers are the threshold values used for the arming function as described in Section 3.8.9. The threshold registers hold independent unsigned 8-bit values for polarity. Each threshold increment is equivalent to one output LSB. Table 18 shows examples of some threshold register values and the corresponding threshold. Table 18. Threshold Register Value Examples | Axis | Axis Type Programmed Thresholds | | d Thresholds | | | |--------------|---------------------------------|-----------------------|-----------------------|------------------------|---------------------------| | Range<br>(g) | Sensitivity<br>(g/LSB) | Positive<br>(Decimal) | Negative<br>(Decimal) | Positive Threshold (g) | Negative Threshold<br>(g) | | 20 | 0.04097 | 100 | 50 | 4.10 | -2.05 | | 20 | 0.04097 | 255 | 0 | 10.45 | Disabled | | 50 | 0.1024 | 50 | 20 | 5.12 | -2.05 | | 120 | 0.24414 | 20 | 10 | 4.88 | -2.44 | If either the positive or negative threshold is programmed to \$00, comparisons are disabled for only that polarity. The arming function still operates for the opposite polarity. If both the positive and negative arming thresholds are programmed to \$00, the Arming function is disabled, and the output pin is disabled, regardless of the value of the A\_CFG bits in the DEVCFG register. ### 3.1.10 Device Status Register (DEVSTAT) The device status register is a read-only register. A read of this register clears the status flags affected by transient conditions. Reference Section 4.5 for details on the MMA685x response for each status condition. **Table 19. Device Status Register** | Location Bit | | | | | | | | | | | |--------------|----------|--------|-----------------|------|---------|---------|---|--------|--------|--| | Address | Register | 7 | 7 6 5 4 3 2 1 0 | | | | | | | | | \$14 | DEVSTAT | UNUSED | IDE | SDOV | DEVINIT | MISOERR | 0 | OFFSET | DEVRES | | #### 3.1.10.1 Unused Bit (UNUSED) The unused bit has no impact on operation or performance. When read this bit may be '1' or '0'. #### 3.1.10.2 Internal Data Error Flag (IDE) The internal data error flag is set if a customer or OTP register data CRC fault or other internal fault is detected as defined in Section 4.5.5. The internal data error flag is cleared by a read of the DEVSTAT register. If the error is associated with a CRC fault in the writable register array, the fault will be re-asserted and will require a device reset to clear. If the error is associated with the data stored in the fuse array, the fault will be re-asserted even after a device reset. #### 3.1.10.3 Sigma Delta Modulator Over Range Flag (SDOV) The sigma delta modulator over range flag is set if the sigma delta modulator becomes saturated. The SDOV flag is cleared by a read of the DEVSTAT register. ### 3.1.10.4 Device Initialization Flag (DEVINIT) The device initialization flag is set during the interval between negation of internal reset and completion of internal device initialization. DEVINIT is cleared automatically. The device initialization flag is not affected by a read of the DEVSTAT register. #### 3.1.10.5 SPI MISO Data Mismatch Error Flag (MISOERR) The MISO data mismatch flag is set when a MISO Data mismatch fault occurs as specified in Section 4.5.2. The MISOERR flag is cleared by a read of the DEVSTAT register. #### 3.1.10.6 Offset Monitor Over Range Flags (OFFSET) The offset monitor over range flag is set if the acceleration signal reaches the specified offset limit. The offset monitor over range flags are cleared by a read of the DEVSTAT register. ### 3.1.10.7 Device Reset Flag (DEVRES) The device reset flag is set during device initialization following a device reset. The device reset flag is cleared by a read of the DEVSTAT register. # 3.1.11 Count Register (COUNT) The count register is a read-only register which provides the current value of a free-running 8-bit counter derived from the primary oscillator. A 10-bit pre-scaler divides the primary oscillator frequency by 1024. Thus, the value in the register increases by one count every 128 $\mu$ s and the counter rolls over every 32.768 ms. Table 20. Count Register | Loca | ation | Bit | | | | | | | | | |---------|----------|----------|----------|----------|----------|----------|----------|----------|----------|--| | Address | Register | 7 | 6 5 | | 4 | 3 | 2 | 1 | 0 | | | \$15 | COUNT | COUNT[7] | COUNT[6] | COUNT[5] | COUNT[4] | COUNT[3] | COUNT[2] | COUNT[1] | COUNT[0] | | | Reset | Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | #### 3.1.12 Offset Correction Value Registers (OFFCORR) The offset correction value register is a read-only register which contain the most recent offset correction increment / decrement value from the offset cancellation circuit. The value stored in this register indicates the amount of offset correction being applied to the SPI output data. The values have a resolution of 1 LSB. **Table 21. Offset Correction Value Register** | Loca | ation | Bit | | | | | | | | | |---------|-----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--| | Address | Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | \$16 | OFFCORR_X | OFFCORR_X[7] | OFFCORR_X[6] | OFFCORR_X[5] | OFFCORR_X[4] | OFFCORR_X[3] | OFFCORR_X[2] | OFFCORR_X[1] | OFFCORR_X[0] | | | Reset | Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | #### 3.1.13 Reserved Registers (Reserved) Registers \$1C and \$1D are reserved. A write to the reserved bits must always be logic '0' for normal device operation and performance. **Table 22. Reserved Registers** | Loca | ation | | Bit | | | | | | | | | |-------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|--|--| | Address | Register | 7 | 6 | 5 | | 3 | 2 | 1 | 0 | | | | \$1C | Reserved | | | \$1D | Reserved | | | Reset Value | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | # 3.2 Customer Accessible Data Array CRC Verification # 3.2.1 OTP Shadow Register Array CRC Verification The OTP shadow register array is verified for errors using a 3-bit CRC. The CRC verification uses a generator polynomial of $g(x) = X^3 + X + 1$ , with a seed value = '111'. If a CRC error is detected in the OTP array, the IDE bit is set in the DEVSTAT register. # 3.2.2 Writable Register CRC Verification The writable registers in the data array are verified for errors using a 3-bit CRC. The CRC verification is enabled only when the ENDINIT bit is set in the DEVCFG register. The CRC verification uses a generator polynomial of $g(x) = X^3 + X + 1$ , with a seed value = '111'. If a CRC error is detected in the writable register array, the IDE bit is set in the DEVSTAT register. # 3.3 Voltage Regulators Separate internal voltage regulators supply the analog and digital circuitry. External filter capacitors are required, as shown in Figure 1. The voltage regulator module includes voltage monitoring circuitry which indicates a device reset until the external supply and all internal regulated voltages are within predetermined limits. A reference generator provides a stable voltage which is used by the $\Sigma\Delta$ converters. Figure 7. Power Supply Figure 8. Voltage Monitoring # 3.3.1 C<sub>REG</sub> Failure Detection The digital supply voltage regulator is designed to be unstable with low capacitance. If the connection to the $V_{REG}$ capacitor becomes open, the digital supply voltage will oscillate and cause either an undervoltage, or overvoltage failure within one internal sample time. This failure will result in one of the following: - The DEVRES flag in the DEVSTAT register will be set. MMA685x will respond to SPI acceleration requests as defined in Table 27. - 2. MMA685x will be held in RESET and be non-responsive to SPI requests. # 3.3.2 C<sub>REGA</sub> Failure Detection The analog supply voltage regulator is designed to be unstable with low capacitance. If the connection to the V<sub>REGA</sub> capacitor becomes open, the analog supply voltage will oscillate and cause either an undervoltage, or overvoltage failure within one internal sample time. The DEVRES flag in the DEVSTAT register will be set. MMA685xMMA685x will respond to SPI acceleration requests as defined in Table 27. **Note:** This feature is only supported with a V<sub>CC</sub> supply voltage in the range of 4.75V to 5.25V. # 3.3.3 V<sub>SS</sub> and V<sub>SSA</sub> Ground Loss Monitor MMA685x detects the loss of ground connection to either $V_{SS}$ or $V_{SSA}$ . A loss of ground connection to $V_{SS}$ will result in a $V_{REG}$ overvoltage failure. A loss of ground connection to $V_{SSA}$ will result in a $V_{REG}$ undervoltage failure. Both failures result in a device reset. #### 3.3.4 SPI Initiated Reset In addition to voltage monitoring, a device reset can be initiated by a specific series of three write operations involving the RES\_1 and RES\_0 bits in the DEVCTL register. Reference Section 3.1.5.1. for details regarding the SPI initiated reset. #### 3.4 Internal Oscillator MMA685x includes a factory trimmed oscillator as specified in Section 2.6. #### 3.4.1 Oscillator Monitor The COUNT register in the customer accessible array is a read-only register which provides the current value of a free-running 8-bit counter derived from the primary oscillator. A 10-bit pre-scaler divides the primary oscillator by 1024. Thus, the value in the COUNT register increases by one count every 128µs, and the register rolls over every 32.768 ms. The SPI master can periodically read the COUNT register, and verify the difference between subsequent register reads against the system time base. 1. The SPI access rates and deviations must be taken into account for this oscillator verification. # 3.5 Transducer The MMA685x transducer is an overdamped mass-spring-damper system described by the following transfer function: $$H(s) = \frac{\omega_n^2}{s^2 + 2 \cdot \xi \cdot \omega_n \cdot s + \omega_n^2}$$ where: $\zeta$ = Damping Ratio $\omega_n$ = Natural Frequency = $2*\Pi*f_n$ Reference Section 2.4 for transducer parameters. #### 3.6 Self-Test Interface The self-test interface applies a voltage to the g-cell, causing deflection of the proof mass. The self-test interface is controlled through SPI write operations to the DEVCFG\_X register described in Section 3.1.7. The ENDINIT bit in the DEVCFG register must also be low to enable self-test. A diagram of the self-test interface is shown in Figure 9. Figure 9. Self-Test Interface The raw self-test deflection can be verified against raw self-test limits using the following equations: $$\Delta ST_{MINI \ IMIT} = FLOOR \cdot (\Delta ST_{MIN}) \cdot [SENS \cdot (1 - \Delta SENS)]$$ $$\Delta \text{ST}_{\text{MAXLIMIT}} = \text{CEIL} \cdot (\Delta \text{ST}_{\text{MAX}}) \cdot [\text{SENS} \cdot (1 + \Delta \text{SENS})]$$ where: $\Delta ST_{MIN} \qquad \text{The minimum self-test deflection over temperature as specified in Section 2.4.} \\ \Delta ST_{MAX} \qquad \text{The maximum self-test deflection over temperature as specified in Section 2.4.} \\$ SENS The sensitivity of the device $\Delta$ SENS The sensitivity tolerance # 3.7 $\Sigma\Delta$ Converters Two sigma delta converters provide the interface between the g-cell and the DSP. The output of each $\Sigma\Delta$ converter is a data stream at a nominal frequency of 1 MHz. Figure 10. ΣΔ Converter Block Diagram # 3.8 Digital Signal Processing Block A digital signal processing (DSP) block is used to perform signal filtering and compensation operations. A diagram illustrating the signal processing flow is shown in Figure 11. Figure 11. Signal Chain Diagram Table 23. MMA685x Signal Chain Characteristics | | Description | Sample<br>Time (µs) | Data Width<br>Bits | Over<br>Bits | Effective<br>Bits | Rounding<br>Resolution Bits | Typical Block<br>Latency | Reference | |------|------------------------|---------------------|--------------------|--------------|-------------------|-----------------------------|--------------------------|----------------| | Α | ΣΔ | 1 | 1 | | 1 | _ | 3.2 μs | Section 3.7 | | В | SINC Filter | 8 | 14 | | 13 | _ | 11.2 μs | Section 3.8.2 | | С | Low Pass Filter | 8/16 | 20 | 6 | 10 | 4 | Reference Section 3.8.3 | Section 3.8.3 | | D | Compensation | 8/16 | 20 | 6 | 10 | 4 | 7.875 µs | Section 3.8.6 | | E | Interpolation | 4/8 | 20 | 6 | 10 | 4 | t <sub>s</sub> / 2 | Section 3.8.7 | | F | Offset<br>Cancellation | 256 | 20 | 6 | 10 | 4 | N/A | Section 3.8.4 | | G, H | SPI Output | 4/8 | _ | _ | 10 | _ | t <sub>s</sub> / 2 | _ | | 1 | PCM Output | 4/8 | _ | _ | 9 | _ | _ | Section 3.8.10 | #### 3.8.1 DSP Clock The DSP is clocked at 8 MHz, with an effective 6MHz operating frequency. The clock to the DSP is disabled for 1 clock prior to each edge of the $\Sigma\Delta$ modulator clock to minimize noise during data conversion. The bit streams from the two $\Sigma\Delta$ converters are processed through independent data paths within the DSP. Figure 12. Clock Generation #### 3.8.2 Decimation Sinc Filter The serial data stream produced by the $\Sigma\Delta$ converter is decimated and converted to parallel values by a 3rd order 16:1 sinc filter with a decimation factor of 8 or 16, depending on the Low Pass Filter selected. $$H(z) = \left[\frac{1 - z^{-16}}{16 \times (1 - z^{-1})}\right]^3$$ Figure 13. Sinc Filter Response, $t_S = 8 \mu s$ # 3.8.3 Low Pass Filter Data from the Sinc filter is processed by an infinite impulse response (IIR) low pass filter. $$H(z) = \frac{\mathsf{n}_0 + (\mathsf{n}_1 \cdot z^{-1}) + (\mathsf{n}_2 \cdot z^{-2}) + (\mathsf{n}_3 \cdot z^{-3}) + (\mathsf{n}_4 \cdot z^{-4})}{\mathsf{d}_0 + (\mathsf{d}_1 \cdot z^{-1}) + (\mathsf{d}_2 \cdot z^{-2}) + (\mathsf{d}_3 \cdot z^{-3}) + (\mathsf{d}_4 \cdot z^{-4})}$$ MMA685x provides the option for one of twelve low-pass filters. The filter is selected with the LPF[3:0] bits in the DEVCFG\_X register. The filter selection options are listed in Section 3.1.7.3, Table 11. Response parameters for the low-pass filter are specified in Section 2.4. Filter characteristics are illustrated in Figures 14, 15, 16, 17, 18 and 19. **Table 24. Low Pass Filter Coefficients** | Description | Sample Time (μs) | | Filter Coef | Group Delay | | | | |----------------------|------------------|----------------|-----------------------|----------------|---------------------|------------------------|--| | 50 Hz LPF | 16 | n <sub>0</sub> | 2.08729034056887e-10 | $d_0$ | 1 | | | | | | n <sub>1</sub> | 8.349134489240434e-10 | d <sub>1</sub> | -3.976249694824219 | | | | | | n <sub>2</sub> | 1.25237777794924e-09 | d <sub>2</sub> | 5.929003009577855 | 26816/f <sub>osc</sub> | | | 100 Hz LPF | 8 | n <sub>3</sub> | 8.349103355433541e-10 | d <sub>3</sub> | -3.929255528257727 | | | | | | n <sub>4</sub> | 2.087307211059861e-10 | $d_4$ | 0.9765022168437554 | | | | | 16 | n <sub>0</sub> | 1.639127731323242e-08 | d <sub>0</sub> | 1 | | | | 150 Hz LPF | | n <sub>1</sub> | 6.556510925292969e-08 | d <sub>1</sub> | -3.928921222686768 | 9024/f <sub>osc</sub> | | | | | n <sub>2</sub> | 9.834768482194806e-08 | $d_2$ | 5.789028996785419 | | | | 300 Hz LPF | 8 | n <sub>3</sub> | 6.556510372902331e-08 | d <sub>3</sub> | -3.791257019240902 | | | | | | n <sub>4</sub> | 1.639128257923422e-08 | d <sub>4</sub> | 0.9311495074496179 | | | | | 16 | n <sub>0</sub> | 5.124509334564209e-08 | $d_0$ | 1 | | | | 200 Hz LPF | | n <sub>1</sub> | 2.049803733825684e-07 | d <sub>1</sub> | -3.905343055725098 | | | | | | n <sub>2</sub> | 3.074705789151505e-07 | d <sub>2</sub> | 5.72004239520561 | 6784/f <sub>osc</sub> | | | 400 Hz LPF | 8 | n <sub>3</sub> | 2.049803958150164e-07 | $d_3$ | -3.723967810019985 | | | | | | n <sub>4</sub> | 5.124510693742625e-08 | $d_4$ | 0.9092692903507213 | | | | | 16 | n <sub>0</sub> | 2.720393240451813e-06 | d <sub>0</sub> | 1 | | | | 200 Hz LPF<br>3-pole | | n <sub>1</sub> | 8.161179721355438e-06 | d <sub>1</sub> | -2.931681632995605 | | | | 0 00.0 | | n <sub>2</sub> | 8.161180123840722e-06 | d <sub>2</sub> | 2.865296718275204 | 5632/f <sub>osc</sub> | | | 400 Hz LPF | 8 | n <sub>3</sub> | 2.720393634345496e-06 | d <sub>3</sub> | -0.9335933215174919 | | | | 3-pole | | n <sub>4</sub> | 0 | d <sub>4</sub> | 0 | | | | | 16 | n <sub>0</sub> | 7.822513580322266e-07 | d <sub>0</sub> | 1 | | | | 400 Hz LPF | | n <sub>1</sub> | 3.129005432128906e-06 | d <sub>1</sub> | -3.811614513397217 | | | | | | n <sub>2</sub> | 4.693508163398543e-06 | d <sub>2</sub> | 5.450666051045118 | 3392/f <sub>osc</sub> | | | 800 Hz LPF | 8 | n <sub>3</sub> | 3.129005428784364e-06 | d <sub>3</sub> | -3.465805771100349 | | | | | | n <sub>4</sub> | 7.822513604678875e-07 | $d_4$ | 0.8267667478030489 | | | | 500 Hz LPF | 16 | n <sub>0</sub> | 1.865386962890625e-06 | d <sub>0</sub> | 1 | | | | | | n <sub>1</sub> | 7.4615478515625e-06 | d <sub>1</sub> | -3.765105724334717 | 2688/f <sub>osc</sub> | | | | | n <sub>2</sub> | 1.119232176112846e-05 | d <sub>2</sub> | 5.319861050818872 | | | | 1000 Hz LPF | 8 | n <sub>3</sub> | 7.4615478515625e-06 | d <sub>3</sub> | -3.34309015036024 | | | | 1000 112 LFF | | n <sub>4</sub> | 1.865386966264658e-06 | d <sub>4</sub> | 0.7883646729233078 | | | Note: Low Pass Filter Figures do not include g-cell frequency response. Figure 14. Low-Pass Filter Characteristics: $f_{\text{C}}$ = 100 Hz, Poles = 4, $t_{\text{S}}$ = 8 $\mu \text{s}$ Figure 15. Low-Pass Filter Characteristics: $f_{C}$ = 300 Hz, Poles = 4, $t_{S}$ = 8 $\mu s$ Figure 16. Low-Pass Filter Characteristics: $f_{\text{C}}$ = 400 Hz, Poles = 4, $t_{\text{S}}$ = 8 $\mu \text{s}$ Figure 17. Low-Pass Filter Characteristics: f\_C = 400 Hz, Poles = 3, t\_S = 8 $\mu s$ Figure 18. Low-Pass Filter Characteristics: $f_{C}$ = 800 Hz, Poles = 4, $t_{S}$ = 8 $\mu s$ Figure 19. Low-Pass Filter Characteristics: $f_{\text{C}}$ = 1000 Hz, Poles = 4, $t_{\text{S}}$ = 8 $\mu \text{s}$ #### 3.8.4 Offset Cancellation MMA685x provides the option to read offset cancelled acceleration data via the SPI by clearing the $\overline{OC}$ bit in the SPI command (reference Section 4.1). A block diagram of the offset cancellation is shown in Figure 20, and response parameters are specified in Section 2.4 and in Table 25. Figure 20. Offset Cancellation Block Diagram In normal operation, the offset cancellation circuit computes a 24,576 sample running average of the acceleration data down-sampled to 256 µs. The running average is compared against positive and negative thresholds to determine the offset correction value that will be applied to the acceleration data. During start up, three phases of moving average sizes are used to allow for faster convergence of misuse input signals. Refer to Table 25 for offset cancellation timing information during startup and normal operation. | Table 25. | Offset | Cancellation | <b>Timing</b> | <b>Specifications</b> | |-----------|--------|--------------|---------------|-----------------------| |-----------|--------|--------------|---------------|-----------------------| | Phase | Start Time of<br>Phase<br>(from POR) | Typical<br>Time in Phase<br>(ms) | # of Samples in<br>Phase | Samples<br>Averaged | OFF_CORR_VALUE<br>Update Rate<br>(ms) | Averaging<br>Period<br>(ms) | Maximum<br>Slew Rate<br>(LSB/s) | Averaging Filter<br>-3dB Frequency<br>(Hz) | |---------|--------------------------------------|----------------------------------|--------------------------|---------------------|---------------------------------------|-----------------------------|---------------------------------|--------------------------------------------| | Start 1 | t <sub>OP</sub> | 524.288 | 2048 | 48 | 2.048 | 12.288 | 122.1 | 36.05 | | Start 2 | t <sub>OP</sub> + 524.288 | 524.288 | 2048 | 384 | 16.38 | 98.304 | 15.26 | 4.506 | | Start 3 | t <sub>OP</sub> + 1048.576 | 524.288 | 2048 | 3072 | 131.1 | 786.432 | 1.907 | 0.5632 | | Normal | t <sub>OP</sub> + 1572.864 | _ | _ | 24576 | 1049 | 6291.456 | 0.2384 | 0.07040 | When the self-test circuitry is active, the offset cancellation block and the offset monitor block are suspended, and the offset correction value is constant. Once the self-test circuitry is disabled, the offset cancellation block remains suspended for the time $t_{ST\ OMB}$ to allow the acceleration output to return to its nominal offset. #### 3.8.5 Offset Monitor MMA685x provides the option for an offset monitor circuit. The offset monitor circuit is enabled when the OFMON bit in the DEVCFG register is programmed to a logic '1'. The output of the offset cancellation circuit is compared against a high and low threshold. If the offset correction value exceeds either the OFFTHR<sub>POS</sub>, or OFFTHR<sub>NEG</sub> threshold, an Offset Over Range condition is indicated. The offset correction value update rate is listed in Table 25: "Maximum Slew Rate". Because the offset monitor uses this value, the offset monitor will also update at this rate. The time to indicate an Offset Over Range is dependent upon the input signal. The offset monitor status remains frozen during self-test, because the offset monitor is based on the offset cancellation circuit, which is also suspended during self-test. The offset monitor is disabled for 2.1 seconds following reset regardless of the state of the OFMON bit. # 3.8.6 Signal Compensation MMA685x includes internal OTP and signal processing to compensate for sensitivity error and offset error. This compensation is necessary to achieve the specified parameters in Section 2.4. MMA685x # 3.8.7 Data Interpolation MMA685x includes 2 to 1 data interpolation to minimize the system sample jitter. Each result produced by the digital signal processing chain is delayed one half of a sample time, and the interpolated value of successive samples is provided between sample times. This operation is illustrated in Figure 21. Figure 21. Data Interpolation Timing The effect of this interpolation at the system level is a 50% reduction in sample jitter. Figure 22 shows the resulting output data for an input signal. Figure 22. Data Interpolation Example # 3.8.8 Acceleration Data Timing The MMA685x SPI uses a request/response protocol, where a SPI transfer is completed through a sequence of 2 phases. Reference Section 4 for more details regarding the SPI protocol. In order to provide the most recent acceleration data for each request, MMA685x latches the associated data for an acceleration request at the falling edge of $\overline{CS}$ for the acceleration response message (the subsequent SPI transfer). The most recent sample available from the DSP (including interpolation), is latched, providing a maximum latency of 1\* $t_S$ relative to the falling edge of $\overline{CS}$ . Figure 23. Acceleration Data Timing #### 3.8.9 Arming Function MMA685x provides the option for an arming function with 3 modes of operation. The operation of the arming function is selected by the state of the A\_CFG bits in the DEVCFG register. Reference Section 4.5 for the operation of the Arming function with exception conditions. Error conditions do not impact prior arming function responses. If an error occurs after an arming activation, the corresponding pulse stretch for the existing arming condition will continue. However, new acceleration reads will not update the arming function regardless of the acceleration value. #### 3.8.9.1 Arming Function: Moving Average Mode In moving average mode, the arming function runs a moving average on the offset cancelled output. The number of samples used for the moving average (k) is programmable via the AWS\_x[1:0] bits in the ARMCFGX register. Reference Section 3.1.8 for register details. $$ARM_MA_n = (OC_n + OC_{n-1} + ... + OC_{n+1-k})/k$$ Where n is the current sample. The sample rate is determined by the SPI acceleration data sample rate. At the falling edge of $\overline{CS}$ for an acceleration data SPI response, the moving average is updated with a new sample. Reference Figure 26. The SPI acceleration data sample rate must meet the minimum time between requests ( $t_{ACC}$ REQ x) specified in Section 2.5. The moving average output is compared against positive and negative 8-bit thresholds that are programmed via the ARMT\_x registers. Reference Section 3.1.9 for register details. If the moving average equals or exceeds either threshold, an arming condition is indicated, the ARM output is asserted, and the pulse stretch counter is set as described in Section 3.8.9.4. The ARM output is de-asserted only when the pulse stretch counter expires. Figure 26 shows the arming output operation for different SPI conditions. Figure 24. Arming Function Block Diagram - Moving Average Mode ### 3.8.9.2 Arming Function: Count Mode In count mode, the arming function compares each input sample against positive and negative thresholds that are programmed via the ARMT\_x registers. Reference Section 3.1.9 for register details. If the sample equals or exceeds either threshold, a sample counter is incremented. If the sample does not exceed either threshold, the sample counter is reset to zero. The sample rate is determined by the SPI acceleration data sample rate. At the falling edge of $\overline{CS}$ for an acceleration data SPI response, a new sample is compared against the thresholds. Reference Figure 26. The SPI acceleration data sample rate must meet the minimum time between requests ( $t_{ACC}$ REQ $_x$ ) specified in Section 2.5. A sample count limit is programmable via the AWS\_x[1:0] bits in the ARMCFG register. If the sample count reaches the programmable sample count limit, an arming condition is indicated, the ARM output is asserted and the pulse stretch counter is set as described in Section 3.8.9.4. The ARM output is de-asserted only when the pulse stretch counter expires. Figure 26 shows the arming output operation for different SPI conditions. Figure 25. Arming Function Block Diagram - Count Mode Figure 26. MMA685x Arming Condition, Moving Average and Count Mode ### 3.8.9.3 Arming Function: Unfiltered Mode On the falling edge of $\overline{CS}$ for an acceleration response, the most recent available DSP sample is compared against positive and negative thresholds that are programmed via the ARMT\_x registers. Reference Section 3.1.9 for register details. If the sample equals or exceeds either threshold, an arming condition is indicated. Once an arming condition is indicated for the ARM output is asserted when $\overline{\text{CS}}$ is asserted and the MISO data includes an acceleration response. The pulse stretch function is not applied in Unfiltered mode. Figure 27 contains a block diagram of the Arming Function operation in Unfiltered Mode. Figure 28 shows the Arming output operation under the different SPI request conditions. Figure 27. Arming Function Block Diagram - Unfiltered Mode Figure 28. MMA685x Arming Conditions, Unfiltered Mode #### 3.8.9.4 Arming Pulse Stretch Function A pulse stretch function can be applied to the arming output in moving average mode, or count mode. If the pulse stretch function is not used (APS[1:0] = '00'), the arming output is asserted if and only if an arming condition exists after the most recent evaluated sample. The arming output is de-asserted if and only if an arming condition does not exist after the most recent evaluated sample. If the pulse stretch function is used, (APS[1:0] not equal '00'), the arming output is controlled only by the value of the pulse stretch timer value. If the pulse stretch timer value is non-zero, the arming output is asserted. If the pulse stretch timer is zero, the arming output is de-asserted. The pulse stretch counter continuously decrements until it reaches zero. The pulse stretch counter is reset to the programmed pulse stretch value if and only if an arming condition exists after the most recent evaluated sample. Reference Figure 26 The desired pulse stretch time is programmable for via the APS[1:0] bits in the ARMCFG register. Exception conditions listed in Section 4.5 do not impact prior arming function responses. If an exception occurs after an arming activation, the corresponding pulse stretch for the existing arming condition will continue. However, new acceleration reads will not reset the pulse stretch counter regardless of the acceleration value. #### 3.8.9.5 Arming Pin Output Structure The arming output pin structure can be set to active high, or active low with the A\_CFG bits in the DEVCFG register as described in Section 3.1.6.5. The active high and active low pin output structures are shown in Figure 29. Figure 29. Arming Function - Pin Output Structure ### 3.8.10 PCM Output Function MMA685x provides the option for a PCM output function. The PCM output is enabled by setting the A\_CFG bits in the DEVCFG register to the appropriate state as described in Section 3.1.6.5. When the PCM function is enabled, the upper 9 bits of the 10-bit, offset cancelled, output scaled acceleration values are used to generate 8 MHz Pulse Code Modulated signals proportional to the acceleration onto the PCM pin. A block diagram of the PCM output is shown in Figure 30. Exception conditions affect the PCM output as listed in Section 4.5. Figure 30. PCM Output Function Block Diagram #### 3.9 **Serial Peripheral Interface** MMA685x includes a Serial Peripheral Interface (SPI) to provide access to the configuration registers and digital data. Reference Section 4 for details regarding the SPI protocol and available commands. #### 3.10 **Device Initialization** Following power-up, under-voltage reset, or a SPI reset command sequence, MMA685x proceeds through an internal initialization process as shown in Figure 31. Figure 31 also shows the MMA685x performance for an example external system level initialization procedure. Notes:1) Self Test can be enabled and evaluated simultaneously to reduce test time. For failure mode coverage of the arming pins and of potential common axis failures, Freescale recommends independent self test activation. 2) t<sub>STRISE</sub> and t<sub>STFALL</sub> are dependent on the selected LPF group delay. Figure 31. Initialization Process ### 3.11 Overload Response #### 3.11.1 Overload Performance MMA685x is designed to operate within a specified range. Acceleration beyond that range (overload) impacts the output of the sensor. Acceleration beyond the range of the device can generate a DC shift at the output of the device that is dependent upon the overload frequency and amplitude. The MMA685x g-cell is overdamped, providing the optimal design for overload performance. However, the performance of the device during an overload condition is affected by many other parameters, including: - · g-cell damping - Non-linearity - · Clipping limits - Symmetry Figure 32 shows the g-cell, ADC and output clipping of MMA685x over frequency. The relevant parameters are specified in Section 2.1, and Section 2.6. Figure 32. Output Clipping Vs. Frequency ### 3.11.2 Sigma Delta Over Range Response Over range conditions exist when the signal level is beyond the full-scale range of the device but within the computational limits of the DSP. The $\Sigma\Delta$ converter can saturate at levels above those specified in Section 2.1 ( $G_{ADC\_CLIP}$ ). The DSP operates predictably under all cases of over range, although the signal may include residual high frequency components for some time after returning to the normal range of operation due to non-linear effects of the sensor. ### 4 SPI Communications Communication with MMA685x is completed through synchronous serial transfers via SPI. MMA685x is a slave device configured for CPOL = 0, CPHA = 0, MSB first. SPI transfers are completed through a sequence of two phases. During the first phase, the type of transfer and associated control information is transmitted from the SPI master to MMA685x. Data from MMA685x is transmitted during the second phase. Any activity on MOSI or SCLK is ignored when CS is negated. Consequently, intermediate transfers involving other SPI devices may occur between phase one and phase two. Refer to Figure 33. Figure 33. SPI Transfer Detail ### 4.1 SPI Command Format Commands are transferred from the SPI master to MMA685x. Valid commands fall into two categories: register operations, and acceleration data requests. **Table 26. SPI Command Message Summary** # 4.2 SPI Response Format Table 27. SPI Response Message Summary | | | | | SB | | | | | | | | | | | | | | LSB | | | |---------------------|----------|-----|---------|-----------|-----|----------|----------|-----------|----------|----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|---------------------------------------|---------------| | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | CMD | Α | AX | OC | 0 | AX | Р | S1 | S0 | Donse to | D8 | D7 | ion Requ | D5 | D4 | D3 | D2 | D1 | D0 | Data Type | Reference | | | | | | | | | | Data Red | | 50 | D1 | | 50 | D-1 | | D2 | | 50 | | | | | | | 0 | | | | | s Offset | • | ed Data | | | | | | | | | | | | | | | 1 | | Tra | ansferre | d Accel | Data is I | Raw Da | ta | | | | | | | | | | | | | | | | | | | AX = A | Axis Req | uested | | | | | | | | | | | | | | | | | | 0 | | Accele | eration D | | sponse | | | | | | | | | | | | | | | | | 1 | | | N | | | | | | | | | | | | | | | | | | | | | ı | P = Od | | | | | | | 7 | | | | | | | | | | | | | | 0 | 0 | ા | | evice Sta | (ENDIN | IT – '0'\ | | - | | | | | | | | | | | | | | 0 | 1 | | | | ta Requ | | | - | | | | | | | | | | | | | | 1 | 0 | ST | | | t Over ra | | esent | | | | | | | | | | | | | | | 1 | 1 | | Internal | Error Pr | esent / S | SPI Erro | r | | | | | | | | CMD | Α | AX | OC | 0 | AX | Р | S1 | S0 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Data Type | Reference | | | 1 | 0 | OC | 0 | 0 | Р | 0 | 1 | | | | | | ation Dat | | | | | Accel | | | Valid<br>Accel | 1 | 0 | OC | 0 | 0 | P | 1 | 0 | | | | Self-Tes | | | | | | | Accel | | | Data | 1 | 0 | OC OC | 0 | 0 | P<br>P | 0 | 0 | | Acc | eleration | n Data, I | | cel Requ | • | NDINII | ='0') | | Accel<br>N/A | Section 4.3 | | Request | 1 | 1 | OC | 0 | 1 | P | 1 | 0 | | | | | | cel Requ | | | | | N/A | | | | 1 | 1 | OC | 0 | 1 | Р | 0 | 0 | | | | | | cel Requ | | | | | N/A | | | | L - | | | | l | l | | | l | | | | | | | | | | | | | | | | М | SB | | | | | | | | | | | | | | LSB | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | CMD | Α | AX | D.15 | D11 | | | D. / / | | | | | er Acces | | | - Bo | - Bo | | | Data Type | Reference | | D : 1 | | | D15 | D14 | AX | Р | D11 | D10 | D9 | D8 | D7<br>D7 | D6<br>D6 | D5<br>D5 | D4<br>D4 | D3 | D2<br>D2 | D1<br>D1 | D0<br>D0 | | | | Register<br>Write | 0 | 1 | 0 | 0 | 1 | Р | 1 | 1 | 1 | 0 | | D0 | | Conten | | | Di | Do | Register Write | Section 4.4.1 | | | | | | | l . | l | l . | | l | | <u> </u> | | | | | <b>J</b> | | | | | | Register | 0 | 0 | 0 | 1 | 0 | Р | 1 | 1 | 1 | 0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Register Read | Section 4.4.2 | | Read | U | O | Ū | ' | O | ı. | ' | | ' | Ŭ | | | С | ontents | of Regis | ter | | | rtegister rtead | Occilon 4.4.2 | | | | | | OD | | | | | | | | | | | | | | 1.00 | | | | | | | М<br>15 | ISB<br>14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB<br>0 | | | | | | 431 | 10 | 17 | 10 | 12 | | 10 | | | sponses | | <u> </u> | _ | <u> </u> | | | | | | | CMD | Α | AX | D15 | D14 | AX | Р | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Data Type | Reference | | Invalid | | | | | | | | | | | | | | | | | | | Register Setting | Continue 4.0 | | Accel<br>Request | Х | х | | | | | | | | | | | | | | | | | Mismatch | Section 4.3 | | Internal | | | | | | | | | | | | | | | | | | | IDE Bit Set | | | Error | х | х | | | | | | | | | | | | | | | | | (Excl. Self-Test),<br>DEVINIT Bit Set | Section 4.5.5 | | Present | | | 0 | 0 | 0 | P | 1 | 1 | | | | | | 0000 0 | | | | | DEVRES Bit Set | | | MISO<br>Error | х | х | | | | | <u>'</u> | ' | | | | SE | 0 = 0: 10 | 0000 0 | 000 | | | | MISO Error on<br>Previous Msg | Section 4.5.2 | | | | | | | | | | | | | | | | | | | | | MOSI Parity<br>CMD Bit 15 = 1 | | | SPI Error | х | х | | | | | | | | | | | | | | | | | SPI Timing Err | Section 4.5.1 | | | | | | | | | | | | | | | | | | | | | SPI Mismatch Err<br>SPI Protocol Errs | | | Invested | $\vdash$ | | | | | | | | | | | | | | | | | | Invalid Reg Addr, | | | Invalid<br>Register | 0 | x | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Write while ENDINIT set, | Section 4.4 | | Request | | | | | | | | | | | | | | | | | | | Write to R/O Reg | | | Self-Test<br>Error | 0 | х | 0 | 0 | 1 | Р | 1 | 1 | | • | | | | 00000 | | | | | IDE Bit set due to<br>Self-Test Error | Section 4.5.5 | | EIIOI | | | | | | <u> </u> | | 1 | <u> </u> | | | ) SL | ) = U: 10 | , 0000 0 | 000 | | | | Sell-Test Ellor | | #### 4.3 Acceleration Data Transfers Acceleration data requests are initiated when the Acceleration bit of the SPI command message (A) is set to a logic '1'. The Axis Selection bit (AX) and the Offset Cancellation Selection bit $(\overline{OC})$ of the command message select the type of acceleration data requested, as shown in Table 28 Table 28. Acceleration Data Request | Acceleration Data F | Data Type | | | |-------------------------|---------------------------------|-----------------------|--| | Axis Selection Bit (AX) | Offset Cancellation Select (OC) | Data Type | | | 0 | 0 | Offset Cancelled Data | | | 0 | 1 | Raw Data | | | 1 | 0 | Invalid Accel Request | | | 1 | 1 | Invalid Accel Request | | To verify that MMA685x is configured as expected, each acceleration data request includes the configuration information that impacts the output data. The requested configuration is compared against the data programmed in the writable register array. Details are shown in Table 29. Table 29. Acceleration Data Request Configuration Information | Programmable Option | Command Message Bit | Writable Register Information | | | |-------------------------------|---------------------|-----------------------------------------------|--|--| | Signed or Unsigned Data | SD | DEVCFG[4] (SD) | | | | Arming Function or PCM Output | ARM | DEVCFG[2] DEVCFG[1] (A_CFG[2] A_CFG[1]) | | | If the data listed in Table 29 does not does not match, an Acceleration Data Request Mismatch failure is detected and no acceleration data is transmitted. Reference Section 4.5.3.1. Acceleration data request commands include a parity bit (P). Odd parity is employed. The number of logic '1' bits in the acceleration data request command must be an odd number. Acceleration data is transmitted on the next SPI message if and only if all of the following conditions are met: - The DEVINIT bit in the DEVSTAT register is not set - The DEVRES bit in the DEVSTAT register is not set - The IDE bit in the DEVSTAT register is not set (Reference Section 4.5.5) - No SPI Error is detected (Reference Section 4.5.1) - No MISO Error is detected (Reference Section 4.5.2) - No Acceleration Data Request Mismatch failure is detected (Reference Section 4.5.3.1) - No Self-Test Error is present (reference Section 4.5.5.2) If the above conditions are met, MMA685x responds with a "valid acceleration data request" response as shown in Table 27. Otherwise, MMA685x responds as specified in Section 4.5. #### 4.4 Register Access Operations Two types of register access operations are supported; register write, and register read. Register access operations are initiated when the acceleration bit (A) of the command message is set to a logic '0'. The operation to be performed is indicated by the Access Selection bit (AX) of the command message. | Access Selection Bit (AX) | Operation | |---------------------------|----------------| | 0 | Register Read | | 1 | Register Write | Register Access operations include a parity bit (P). Odd parity is employed. The number of logic '1' bits in the Register Access operation must be an odd number. #### 4.4.1 Register Write Request During a register write request, bits 12 through 8 contain a five-bit address, and bits 7 through 0 contain the data value to be written. Writable registers are defined in Table 3. The response to a register write operation is shown in Table 27. The response is transmitted on the next SPI message if and only if all of the following conditions are met: - No SPI Error is detected (Reference Section 4.5.1) - No MISO Error is detected (Reference Section 4.5.2) - The ENDINIT bit is cleared (Reference Section 3.1.6.2) - This applies to all registers with the exception of the DEVCTL register - No Invalid Register Request is detected (Reference Section 4.5.3.2) If the above conditions are met, MMA685x responds to the register write request as shown in Table 27. Otherwise, MMA685x Responds as specified in Section 4.5. Register write operations do not occur internally until the transfer during which they are requested has been completed. In the event that a SPI Error is detected during a register write transfer, the write operation is not completed. ### 4.4.2 Register Read Request During a register read request, bits 12 through 8 contain the five-bit address for the register to be read. Bits 7 through 0 must be logic '0'. Readable registers are defined in Table 3. The response to a register read operation is shown in Table 27. The response is transmitted on the next SPI message if and only if all of the following conditions are met: - No SPI Error is detected (Reference Section 4.5.1) - No MISO Error is detected (Reference Section 4.5.2) - No Invalid Register Request is detected (Reference Section 4.5.3.2) If the above conditions are met, MMA685x responds to the register read request as shown in Table 27. Otherwise, MMA685x responds as specified in Section 4.5. ### 4.5 Exception Handling The following sections describe the conditions for each detectable exception, and the MMA685x response for each exception. In the event that multiple exceptions exist, the exception response is determined by the priority listed in Table 30. **Table 30. SPI Error Response Priority** | Error Priority | Exception | Effect on Data | | | | | | |----------------|---------------------------|----------------|---------------|------------|--|--|--| | Error Priority | Exception | SPI Data | Arming Output | PCM Output | | | | | 1 | SPI Error | Error Response | No Update | No Effect | | | | | 2 | SPI MISO Error | Error Response | No Update | No Effect | | | | | 3 | Invalid Request | Error Response | No Update | No Effect | | | | | 4 | DEVINIT Bit Set | Error Response | No Update | Disabled | | | | | 5 | DEVRES Error | Error Response | No Update | Disabled | | | | | 6 | CRC Error | Error Response | No Update | No Effect | | | | | 7 | Self-Test Error | Error Response | No Update | No Effect | | | | | 8 | Offset Monitor Over Range | No Effect | No Effect | No Effect | | | | | 9 | ΣΔ Over Range | No Effect | No Effect | No Effect | | | | #### 4.5.1 SPI Error The following SPI conditions result in a SPI error: - SCLK is high when CS is asserted - the number of SCLK rising edges detected while $\overline{\text{CS}}$ is asserted is not equal to 16 - SCLK is high when <del>CS</del> is negated - · Command message parity error (MOSI) - Bit 15 of Acceleration Data Request is not equal to '0' - Bits 3 through 11 of an Acceleration Request are not equal to '0' - Bits 0 through 7 of a Register Read Reguest are not equal to '0' MMA685x responds to a SPI error with a "SPI Error" response as shown in Table 27. This applies to both acceleration data request SPI errors, and Register Access SPI errors. The arming function will not be updated if a SPI Error is detected. The PCM output is not affected by a SPI Error. ### 4.5.2 SPI Data Output Verification Error MMA685x includes a function to verify the integrity of the data output to the MISO pin. The function reads the data transmitted on the MISO pin and compares it against the data intended to be transmitted. If any one bit doesn't match, a SPI MISO Mismatch Fault is detected and the MISOERR flag in the DEVSTAT register is set. If a valid SPI acceleration request message is received during the SPI transfer with the MISO mismatch failure, the SPI acceleration request message is ignored and MMA685x responds with a "MISO Error" response during the subsequent SPI message (reference Table 27). The Arming function is not updated if a MISO mismatch failure occurs. The PCM function is not affected by the MISO mismatch failure. If a valid SPI register write request message is received during the SPI transfer with the MISO mismatch failure, the register write is completed as requested, but MMA685x responds with a "MISO Error" response as shown in Table 27, during the subsequent SPI message. If a valid SPI register read request message is received during the SPI transfer with the MISO mismatch failure, the register read is ignored and MMA685x responds with a "MISO Error" response as shown in Table 27, during the subsequent SPI message. If the register read request is for the DEVSTAT register, the DEVSTAT register will not be cleared. In all cases, the MISOERR flag in the DEVSTAT register will remain set until a successful SPI Register Read Request of the DEVSTAT register is completed. Figure 34. SPI Data Output Verification #### 4.5.3 Invalid Requests #### 4.5.3.1 Invalid Acceleration Request The following conditions result in an "Invalid Acceleration Request" error: - The Axis Selection bit (AX) in the Command message is set - The SPI "Acceleration Data Request" Command data listed in Section 4.3, Table 29 does not match the internal register settings MMA685x responds to an "Invalid Acceleration Request" error with an "Invalid Accel Request" response as specified in Table 27 on the subsequent SPI message only. No internal fault is recorded. The arming function will not be updated if an "Acceleration Data Request Mismatch" Error is detected. The PCM output is not affected by the "Acceleration Data Request Mismatch" error. Register operations will be executed as specified in Section 4.4. #### 4.5.3.2 Invalid Register Request The following conditions result in an "Invalid Register Request" error: - An attempt is made to write to an un-writable register (Writable registers are defined in Section 3.1, Table 3). Attempts to write to registers \$0D, \$0F, \$11, and \$13 will also result in an error. - · An attempt is made to write to a register while the ENDINIT bit in the DEVCFG register is set - This applies to all registers with the exception of the DEVCTL register - An attempt is made to read an un-readable register (Readable registers are defined in Section 3.1, Table 3). Attempts to read registers \$07, \$0D, \$0F, \$11, and \$13 will also result in an error. MMA685x responds to an Invalid Register Request" error with an "Invalid Register Request" response as shown in Table 27. #### 4.5.4 Device Reset Indications If the DEVINIT, or DEVRES bit is set in the DEVSTAT register as described in Section 3.1.10, MMA685x will respond to acceleration data requests with an "Internal Error Present" response until the bits are cleared in the DEVSTAT register. The DEVINIT bit is cleared automatically when device initialization is complete (Reference $t_{OP}$ in Section 2.6). The DEVRES bit is cleared on a read of the DEVSTAT register. The arming function will not be updated on Acceleration Data Request commands if the DEVINIT or DEVRES bit is set in the DEVSTAT register. The PCM output is disabled if the DEVINIT or DEVRES bit is set. #### 4.5.5 Internal Error The following errors will result in an internal error, and set the IDE bit in the DEVSTAT register: - · OTP CRC Failure - · Writable Register CRC Failure - · Self-Test Error - · Invalid internal logic states #### 4.5.5.1 CRC Error If the IDE bit is set in the DEVSTAT register due to an OTP Shadow Register or Writable Register CRC failure as described in Section 3.2, MMA685x will respond to acceleration data requests with an "Internal Error Present" response until the IDE bit is cleared in the DEVSTAT register. The arming function will not be updated on Acceleration Data Request commands if a CRC Error is detected. The PCM output is not affected by the CRC error. If the CRC error is in the writable register array, and the ENDINIT bit in the DEVCFG register has been set, the error can only be cleared by a device reset. The IDE bit will not be cleared on a read of the DEVSTAT register. If the CRC error is in the OTP shadow register array, the error cannot be cleared. Register operations will be executed as specified in Section 4.4. ### 4.5.5.2 Self-Test Error If the IDE bit is set in the DEVSTAT register due to a Self-Test activation failure, MMA685x will respond to acceleration data requests with a "Self-Test Error" response until the IDE bit is cleared in the DEVSTAT register. The arming function will not be updated on Acceleration Data Request commands if a Self-Test Error is detected. The PCM output is not affected by the Self-Test Error. The IDE bit in the DEVSTAT register will remain set until a read of the DEVSTAT register occurs, even if the internal failure is removed. If the internal error is still present when the DEVSTAT register is read, the IDE bit will remain set. Register operations will be executed as specified in Section 4.4. #### 4.5.6 Offset Monitor Over Range If an offset monitor over range is present as described in Section 3.8.5, MMA685x will respond to an acceleration request with a "Valid Acceleration Data Request" response, but the Status bits (S[1:0]) will be set to '10'. The arming function will be updated on Acceleration Data Request commands even if an Offset Monitor Over Range is detected. Once the over range condition is removed, MMA685x will respond to acceleration requests with a "Valid Acceleration Data Request" response with the Status bits (S[1:0]) set to '10' on the next SPI transfer, and a "Valid Acceleration Data Request" response with normal status on subsequent SPI transfers. The OFF bit in the DEVSTAT register will remain set until a read of the DEVSTAT register occurs. The PCM output is not affected by the offset monitor over range condition. Register operations will be executed as specified in Section 4.4. ### 4.5.7 $\Sigma\Delta$ Over Range If a $\Sigma\Delta$ Over Range failure is present as described in Section 3.11.2, MMA685x will respond to acceleration data requests with a "Valid Acceleration Data Request" response, but the Status bits (S[1:0]) will be set to '10'. The arming function will be updated on Acceleration Data Request commands even if a $\Sigma\Delta$ Over Range is detected. Once the over range condition is removed, MMA685x will respond to acceleration requests with a "Valid Acceleration Data Request" response with the Status bits (S[1:0]) set to '10' on the next SPI transfer, and a "Valid Acceleration Data Request" response with normal status on subsequent SPI transfers. The SDOV bit in the DEVSTAT register will remain set until a read of the DEVSTAT register occurs. The PCM output is not affected by the $\Sigma\Delta$ over range condition. Register operations will be executed as specified in Section 4.4. ### 4.6 Initialization SPI Response The first data transmitted by MMA685x following reset is the SPI Error response shown in Table 27. This ensures that an unexpected reset will always be detectable. MMA685x will respond to all acceleration data requests with the "Invalid Acceleration Data Request" response until the DEVRES bit in the DEVSTAT register is cleared via a read of the DEVSTAT register. The arming function will not be updated on Acceleration Data Request commands until the DEVRES bit in the DEVSTAT register is cleared. ### 4.7 Acceleration Data Representation Acceleration values are determined from the 10-bit digital output (DV) using the following equations: Acceleration= Sensitivity $_{ISB} \times DV$ For Signed Data Acceleration= Sensitivity $I_{SB} \times (DV - 512)$ For Unsigned Data The linear range of digital values for signed data is -480 to +480, and for unsigned data is 32 to 992. Resulting ranges and some nominal acceleration values are shown in Table 31. **Table 31. Nominal Acceleration Data Values** | | | Nominal Acceleration | | | | | |---------------------------|-------------------------|-------------------------------------------|-------------------------------------|--|--|--| | Unsigned<br>Digital Value | Signed<br>Digital Value | Trimmed for<br>Maximum Sensitivity<br>(g) | Trimmed for<br>Maximum Range<br>(g) | | | | | 993 - 1023 | 481 - 511 | Unus | sed | | | | | 992 | 480 | 19.666 | 117.19 | | | | | 991 | 479 | 19.625 | 116.94 | | | | | • | • | : | • | | | | | 514 | 2 | +0.082 | +0.488 | | | | | 513 | 1 | +0.041 | +0.244 | | | | | 512 | 0 | 0 | 0 | | | | | 511 | -1 | -0.041 | -0.244 | | | | | 510 | -2 | -0.082 | -0.488 | | | | | • | • | : | • | | | | | 33 | -479 | -19.625 | -116.94 | | | | | 32 | -480 | -19.666 | -117.19 | | | | | 1 - 31 | -481 to -511 | Unus | sed | | | | | 0 | -512 | Fau | ult | | | | Figure 35 shows the how the possible output data codes are determined from the input data and the error sources. The relevant parameters are specified in Section 2.4. Figure 35. MMA685x Acceleration Data Output Vs. Acceleration Input # 5 Package ## 5.1 Case Outline Drawing Reference Freescale Case Outline Drawing # 98ASA00090D http://www.freescale.com/files/shared/doc/package\_info/98ASA00090D.pdf ## 5.2 Recommended Footprint Reference Freescale Application Note AN3111, latest revision: http://www.freescale.com/files/sensors/doc/app\_note/AN3111.pdf **Table 32. Revision History** | Revision number | Revision date | Description of changes | |-----------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | 12/2011 | <ul> <li>Updated ordering table to include Tube options; deleted MMA6852 and MMA6854.</li> <li>Deleted MMA6852 and MMA6854 devices from Electrical Characteristics table, lines 57 and 60. Removed "QR2" from device names, lines 56-59.</li> <li>Updated equation in section 3.6, Self-Test Interface.</li> </ul> | #### How to Reach Us: #### **Home Page:** www.freescale.com #### Web Support: http://www.freescale.com/support #### **USA/Europe or Locations Not Listed:** Freescale Semiconductor, Inc. Technical Information Center, EL516 2100 East Elliot Road Tempe, Arizona 85284 1-800-521-6274 or +1-480-768-2130 www.freescale.com/support #### Europe, Middle East, and Africa: Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) www.freescale.com/support #### Japan: Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com #### Asia/Pacific: Freescale Semiconductor China Ltd. Exchange Building 23F No. 118 Jianguo Road Chaoyang District Beijing 100022 China +86 10 5879 8000 support.asia@freescale.com #### For Literature Requests Only: Freescale Semiconductor Literature Distribution Center 1-800-441-2447 or +1-303-675-2140 Fax: +1-303-675-2150 LDCForFreescaleSemiconductor@hibbertgroup.com Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in Freescale Semiconductor 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. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part. Freescale and the Freescale logo are trademarks of Freescale Semiconductor, Inc., Reg. U.S. Pat. & Tm. Off. Xtrinsic is a trademark of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners. © 2011 Freescale Semiconductor, Inc. All rights reserved. RoHS-compliant and/or Pb-free versions of Freescale products have the functionality and electrical characteristics of their non-RoHS-compliant and/or non-Pb-free counterparts. For further information, see http://www.freescale.com or contact your Freescale sales representative. For information on Freescale's Environmental Products program, go to http://www.freescale.com/epp.