## **Freescale Semiconductor** Technical Data

# **Digital Dual Axis Micromachined Accelerometer**

The MMA62XXKEG is a two-axis member of Freescale's family of SPI-compatible accelerometers. These devices incorporate digital signal processing for filtering, trim and data formatting.

### **Features**

- Available in ±20/20g, ±50/50g, or ±100/100g versions. Additional g-ranges between 20 and 100g may be available upon request
- Full-scale range is independently specified for each axis
- 400 Hz low-pass filter, 0.1 Hz high-pass filter, 4-pole, 16 μs sample time, additional filter options are available
- Ratiometric analog voltage output
- 10-bit digital signed data output
- SPI-compatible serial interface
- Capture/hold input for system-wide synchronization support
- 3.3 or 5 V single supply operation
- On-chip temperature sensor and voltage regulator
- Bidirectional internal self-test
- Minimal external component requirements
- Pb-free 20-pin SOIC package
- Qualified AEC-Q100, Rev. F Grade 2 (-40°C/ +105°C)

### **Typical Applications**

- Crash Detection (Airbag)
- Impact and vibration monitoring
- Shock Detection

## **MMA6222KEG MMA6255KEG MMA621010KEG**

**2-AXIS SPI-COMPATIBLE ACCELEROMETER**



**KEG SUFFIX (Pb-free) 20-LEAD SOIC CASE 475A-02**





\*Part number sourced from a different facility.



MMA6222KEG Rev 0, 12/2009

**VRoHS** 

© Freescale Semiconductor, Inc., 2009. All rights reserved.



Note: If one axis of the MMA62XXKEG sensor is expected to be used as a confirmation of the other axis, Freescale recommends that MMA62XXKEG used in conjunction with an additional sensing/safing device for each axis.

#### **Figure 1-1 Simplified Airbag Application Diagram**

## <span id="page-1-0"></span>**1.1 INTRODUCTION**

The MMA62XXKEG is intended for applications which utilize serial communications as the primary data transfer mechanism. In addition, an analog output with lower accuracy is available.

Device serial number, acceleration range, filter characteristics and status information are available along with acceleration data via the SPI interface. A pair of digital-to-analog converters is enabled to provide ratiometric voltage outputs in addition to the digital acceleration value accessible via the SPI.

## **1.2 BLOCK DIAGRAM**

A block diagram illustrating the major components of the design is shown in [Figure 1-2.](#page-2-0)





<span id="page-2-0"></span>

**Figure 1-3 MMA62XXKEG DSP Block Diagram NOTE: Models of signal chain are available upon request.**

## **1.3 PIN FUNCTIONS**

The pinout for the MMA62XXKEG device is illustrated in [Figure 1-4.](#page-3-0) Pin functions are described below. When self-test is active, the output becomes more positive in both axes if ST1 is cleared, or more negative in both axes if ST1 is set, as described in [Section 3.1.1.](#page-13-0)



N/C: NO INTERNAL CONNECTION



## <span id="page-3-0"></span>**Response to static orientation within 1g field.**

**Figure 1-4 MMA62XXKEG Pinout**

## **1.4 PIN FUNCTION DESCRIPTIONS**

## $1.4.1 \, V_{CC}$

This pin supplies power to the device. Careful printed wiring board layout and capacitor placement is critical to ensure best performance. An external bypass capacitor between this pin and  $V_{SS}$  is required, as described in [Section 1.5.](#page-5-0)

## $1.4.2 \quad V_{SS}$

This pin is the power supply return node for the digital circuitry on the MMA62XXKEG device.

## **1.4.3 VSSA**

This pin is the power supply return node for analog circuitry on the MMA62XXKEG device. An external bypass capacitor between this pin and  $V_{CC}$  is required, as described in [Section 1.5.](#page-5-0)

### **1.4.4 CREG**

This pin is connected to the internal digital circuitry power supply rail. An external filter capacitor must be connected between this pin and  $V_{SS}$ , as described in [Section 1.5](#page-5-0).

## **1.4.5 CREGA**

These pins are connected in parallel to the internal analog circuitry power supply rail. One or two external filter capacitors must be connected between these pins and  $V_{SSA}$ , as described in [Section 1.5.](#page-5-0) Two pins are provided to support redundant connection to the printed wiring board assembly. Redundant external capacitors may be connected to these pins for maximum reliability, as described in [Section 1.5.](#page-5-0)

### **1.4.6 CREF**

These pins are connected in parallel to an internal reference voltage node utilized by the analog circuitry. One or two external filter capacitors must be connected between these pins and  $V_{SSA}$ , as described shown in [Section 1.5.](#page-5-0) Two pins are provided to support redundant connection to the printed wiring board assembly. Redundant external capacitors may be connected to these pins for maximum reliability, as described in [Section 1.5](#page-5-0).

### **1.4.7 VPP**

This pin should be tied directly to  $V_{SS}$ .

## **1.4.8 SCLK**

This input pin provides the serial clock to the SPI port. The state of this pin is also used as a qualifier for externally-controlled reset. An internal pull-down device is connected to this pin. This input may be left unconnected unless it is desired to initiate device reset as described in [Section 1.4.9](#page-4-0).

## <span id="page-4-0"></span>**1.4.9 CS/RESET**

This pin provides two functions. When the SPI is enabled, this pin functions as the chip select input for the SPI port. The state of the D<sub>IN</sub> pin during low-to-high transitions of SCLK is latched internally and D<sub>OUT</sub> is enabled when CS is at a logic low level.

This pin may also be used to initiate a hardware reset. If  $\overline{CS}$  is held low and SCLK is held high for 512  $\mu$ s, the internal reset signal is asserted.

An internal pull-up device is connected to this pin.

## **1.4.10** D<sub>OUT</sub>

This pin functions as the serial data output for the SPI port.

Immediately following device reset,  $D_{\text{OUT}}$  is placed in a high impedance state for approximately 800 μs. At the end of this time,  $D_{O|U}$  is driven high and a 3ms stabilization delay required by the internal circuitry begins. Reset is reported by the device so the system can be aware of potential difficulties if unexpected resets occur.

## 1.4.11  $D_{IN}$

This pin functions as the serial data input to the SPI.

## **1.4.12 CAP/HOLD**

When this input pin is low, the SPI acceleration result registers are updated by the DSP whenever a data sample becomes available. Upon a low-to-high transition of CAP/HOLD, the contents of the acceleration result registers are frozen. The result registers will not be updated so long as this pin remains at a logic '1' level. This pin may be tied directly to  $V_{SS}$  if the hold function is not desired.

## **1.4.13** X<sub>OUT</sub>, Y<sub>OUT</sub>

Two Digital-to-Analog Converters (DACs) translate output of the DSP block into voltage levels proportional to the magnitude of the numerical result and ratiometric to  $V_{CC}$ . The DAC outputs have an inherent accuracy of about ±12%.

## <span id="page-5-0"></span>**1.5 EXTERNAL COMPONENTS**

The connections illustrated below are recommended. Careful printed wiring board layout and component placement is essential for best performance. Low ESR capacitors must be connected to C<sub>REG</sub> and C<sub>REGA</sub> pins for the best performance. A grounded land area with solder mask should be placed under the package for improved shielding of the device from external effects. If a land area is not provided, no signals should be routed beneath the package. See [Figure 1-1](#page-1-0).

## **SECTION 2 PERFORMANCE SPECIFICATION**

## **2.1 MAXIMUM RATINGS**

Maximum ratings are the extreme limits to which the device can be exposed without permanently damaging it. The device contains circuitry to protect the inputs against damage from high static voltages; however, do not apply voltages higher than those shown in the table below. Keep input and output voltages within the range  $V_{SS} \le V \le V_{CC}$ .



Notes:

1. Verified by characterization, not tested in production.

## **2.2 OPERATING RANGE**

The operating ratings are the limits normally expected in the application and define the range of operation.



Notes:

1. Characterized at all values of  $V_L$  and  $V_H$ . Production test is conducted at typical voltage unless otherwise noted.

2. Parameters tested 100% at final test.

## **2.3 ELECTRICAL CHARACTERISTICS**

 $V_L \leq (V_{CC} - V_{SS}) \leq V_H$ ,  $T_L \leq T_A \leq T_H$ ,  $|\Delta T_A| < 4$  K/min unless otherwise specified



<span id="page-7-4"></span><span id="page-7-2"></span><span id="page-7-1"></span>Notes:

1. Parameters tested 100% at final test.

2. Verified by characterization, not tested in production.

3. Tested at  $V_{CC} = V_L$  and  $V_{CC} = V_H$ .

<span id="page-7-3"></span>4. Power supply ripple at frequencies greater than 900 kHz should be minimized to the greatest extent possible.

<span id="page-7-0"></span>5. Devices are trimmed at 100 Hz with 1000 Hz low pass filter selected.

(#) Indicates a FSL significant parameter (CPK > 1.33).

(\*) Indicates a FSL critical parameter (CPK > 1.67).

## **2.3 ELECTRICAL CHARACTERISTICS (CONTINUED)**

 $V_L \leq (V_{CC} - V_{SS}) \leq V_H$ ,  $T_L \leq T_A \leq T_H$ ,  $|\Delta T_A| < 4$  K/min unless otherwise specified



<span id="page-8-1"></span><span id="page-8-0"></span>Notes:

1. Parameters tested 100% at final test.

2. Verified by characterization, not tested in production.

5. Functionality verified 100% via scan.

 $(*)$  Indicates a FSL critical parameter (CPK  $> 1.67$ ).

## **2.3 ELECTRICAL CHARACTERISTICS (CONTINUED)**

 $V_L \leq (V_{CC} - V_{SS}) \leq V_H$ ,  $T_L \leq T_A \leq T_H$ ,  $|\Delta T_A| < 4$  K/min unless otherwise specified



<span id="page-9-2"></span><span id="page-9-1"></span><span id="page-9-0"></span>Notes:

1. Parameters tested 100% at final test.

2. Verified by characterization, not tested in production.

6. Parameters tested 100% at unit probe.

## **2.4 CONTROL TIMING**

 $V_L \leq (V_{CC} - V_{SS}) \leq V_H$ ,  $T_L \leq T_A \leq T_H$ ,  $|\Delta T_A| < 4$  K/min unless otherwise specified



<span id="page-10-4"></span><span id="page-10-0"></span>Notes:

1. Functionality verified 100% via scan. Timing characteristic is directly determined by internal oscillator frequency.

2. Verified by characterization, not tested in production.

3. Parameters tested 100% at final test.

<span id="page-10-1"></span>4. Parameters tested 100% at unit probe.

<span id="page-10-2"></span>5. Devices are trimmed at 100 Hz with 1000 Hz low-pass filter option selected.

<span id="page-10-3"></span>6. Cutoff frequencies shown are -4dB referenced to 0 Hz response, to correspond with previous specifications.





<span id="page-11-0"></span>

<span id="page-11-1"></span>**Figure 2-2 Power Supply Coupling - DAC Outputs**

<span id="page-12-1"></span>

<span id="page-12-0"></span>

## **SECTION 3 INTERNAL MODULES**

## **3.1 ONE-TIME PROGRAMMABLE DATA ARRAY**

A 400-bit programmable data array allows each device to be customized. The array interface incorporates parity circuitry for fault detection along with a locking mechanism to prevent unintended changes. Portions of the array are reserved for factory-programmed trim values. Customer accessible data stored in the array are shown in the table below.

Addresses \$00 - \$0D are associated with the programmable data array. A writable register at address \$0E is provided for device control operations. Two read-only registers at addresses \$0F and \$10 provide status information.

Unused bits within the data array are always read as '0' values. Unprogrammed OTP bits are also read as '0' values.



#### **Table 3-1 Customer Accessible Data**

Type codes

F: Factory programmed OTP location

R: Read-only register

R/W: Read/write register

N/A: Not applicable

## <span id="page-13-0"></span>**3.1.1** '**DEVICE CONTROL REGISTER (DEVCTL)**

A read-write register at address \$0E supports a number of device control operations as described below. Reserved bits within DEVCTL are always read as logic '0' values.





### **3.1.1.1 Reset Control (RES\_1, RES\_0)**

A specific series of three write operations involving these two bits will cause the internal digital circuitry to be reset. The state of the remaining bits in the DEVCTL register do not affect the reset sequence, however any write operation involving this register in which both RES\_1 and RES\_0 are cleared will terminate the sequence.

To reset the internal digital circuitry, the following register write operations must be performed in the order shown:

- 1. Set RES1. RES0 must remain cleared.
- 2. Set RES1 and RES0.
- 3. Clear RES1 and set RES0.

RES1 and RES0 are always read as logic '0' values. After reset sequence has been completed DEVCTL register will read 0X00. It should be noted that after a reset or power-cycle sequence is completed the DEVCTL register reset to the value 0X00.

### **3.1.1.2 Clear Error (CE)**

Setting this bit to a logic '1' state will clear transient error status conditions. It is necessary to either set this bit or perform a device reset if an error condition has been reported by the device before acceleration data transfer can be resumed. The device reset condition may be cleared only after device initialization has completed.

Error conditions and classification are described in [Section 4.2.](#page-24-0)

The state of this bit is always read as logic '0'.

#### **3.1.1.3 High-Pass Filter Bypass (HPFB)**

Setting this bit will remove the high-pass filter from the signal chain within the DSP block. The state of this bit is indicated when DEVCTL is read. This bit is always cleared following reset.

The state of the high-pass filter is frozen when this bit is at a logic '1' level.

#### **3.1.1.4 Self-Test Control (ST1, ST0)**

Bidirectional self-test control is provided through manipulation of these bits. ST1 controls direction while ST0 enables and disables the self-test circuitry. ST1 and ST0 are always cleared following internal reset. When ST0 is set, the high-pass filter is bypassed and the values within the high-pass filter are frozen. Both axes are affected simultaneously by the state of these bits. If the offset monitor is enabled, self-test activation in a single direction should be limited to less than 30 ms.

The state of the ST0 bit is indicated as part of all acceleration results.

#### **3.1.1.5 Y-Axis Signal Inversion Control (YINV)**

This control function is provided as a means to verify operation of the two-channel multiplexor which alternately provides X-axis and Y-axis data to the DSP. An inverter block and multiplexor at the Y-axis input to the DSP are controlled by the YINV bit. Setting this bit when ST0 is set has the effect of changing the sign of acceleration in the Y-axis. Operation of the YINV bit is illustrated in [Figure 3-1](#page-14-0) below. Y-axis inversion may be selected only during self-test; the state of this bit has no effect when ST0 is cleared.

<span id="page-14-0"></span>

**Figure 3-1 Y-Axis Inversion Function**

Self-test operations controlled by YINV along with ST1 and ST0 are summarized in the following table.



#### **Table 3-3 Self-Test Control Operations**

#### **NOTE:**

Offset correction is applied within the DSP, and is not affected by the state of the YINV bit. Consequently, inversion of the Y-axis signal may result in saturation of the Y-axis output value.

Correct operation of the DSP input multiplexor may be confirmed by performing the operations shown in [Figure 3-2](#page-16-0).



**Figure 3-2 DSP Input Multiplexor Verification Flow Chart**

## <span id="page-16-0"></span>**3.1.2 Temperature Sensor Value (TEMP)**

This read-only register contains a signed value which provides a relative temperature indication. The temperature sensor is uncalibrated and its output for a given temperature will vary from one device to the next. The value in this register increases with temperature.

| Location       |          | <b>Bit Function</b> |         |         |         |         |         |         |         |  |
|----------------|----------|---------------------|---------|---------|---------|---------|---------|---------|---------|--|
| <b>Address</b> | Register |                     |         |         |         |         |         |         |         |  |
| \$0F           | TEMP     | TEMP[7]             | TEMP[6] | TEMP[5] | TEMP[4] | TEMP[3] | TEMP[2] | TEMP[1] | TEMP[0] |  |

**Table 3-4 Temperature Sensor Value Register**

## <span id="page-16-1"></span>**3.1.3 Device Status Register (DEVSTAT)**

This read-only register is accessible in all modes.





### **3.1.3.1 Internal Data Error Flag (IDE)**

This flag will be set if a register data parity fault or a marginally programmed fuse is detected. Device reset is required to clear this fault condition. If a parity error is associated with the data stored in the fuse array, this fault condition cannot be cleared. This flag is disabled when the device is in test mode.

### **3.1.3.2 Oscillator Fault Flag (OCSF)**

This flag will be set if the primary oscillator and reference oscillator frequencies vary by an amount greater than the specified tolerance. In normal operating mode, an oscillator fault condition will result in  $D_{OUT}$  being driven high when CS is asserted.

#### **3.1.3.3 Device Initialization Flag (DEVINIT)**

This flag is set during the interval between negation of internal reset and completion of device initialization. DEVINIT is cleared automatically.

#### **3.1.3.4 Temperature Fault Flag (TF)**

This flag is set if the value reported by the on-chip temperature sensor exceeds specified limits. TF may be cleared by writing a logic '1' value to the CE bit in DEVCTL, provided that the fault condition is no longer detected.

#### **3.1.3.5 High-Pass Filter Status (HPF)**

This bit is set when a high-pass filter is present in the DSP signal chain when the HPFB bit has been set.

#### **3.1.3.6 Y-Axis Offset Error Flag (OFF\_Y)**

#### **3.1.3.7 X-Axis Offset Error Flag (OFF\_X)**

The offset error flags are set if the associated signal reaches the specified offset limit. These flags may be cleared by writing a logic '1' value to the CE bit in DEVCTL. Offset faults are not reported for 1.5 seconds following reset.

#### **3.1.3.8 Device Reset Flag (DEVRES)**

This flag is set during device initialization. A logic '1' must be written to the CE bit in the Device Control register (DEVCTL) to clear this bit.

#### **3.1.4 Counter Register (COUNT)**

This read-only register provides the value of a free-running 8-bit counter derived from the primary oscillator. A five-bit prescaler divides the 4 MHz primary oscillator frequency by 32. Thus, the value in the register increases by one count every 8 μs, and the counter rolls over every 2.048 ms.



#### **Table 3-6 Counter Register**

## **SECTION 4 SERIAL COMMUNICATIONS**

Digital data communication with MMA62XXKEG is completed through synchronous serial transfers via the SPI port. Conventional SPI protocol is employed, with MMA62XXKEG acting as a slave device observing CPOL = 0, CPHA = 0, MSB first. A number of data integrity features are incorporated into the transfer protocol.

## **4.1 SPI PROTOCOL**

## **4.1.1 Overview**

Each transfer is completed through a sequence of two operations, termed phases. During the first phase, the type of transfer and associated control information is transmitted from the SPI master to MMA62XXKEG. Data from MMA62XXKEG is transmitted during the second phase. Single-level queuing is employed as illustrated in [Figure 4-1](#page-18-0).



first access following reset

### **Figure 4-1 Transfer Phase Detail**

<span id="page-18-0"></span>Any activity on DIN or SCLK is ignored when CS is negated. Consequently, intermediate transfers involving other SPI devices may occur between Phase One and Phase Two.



**Figure 4-2 Single-Level Communications Queuing Detail**

The first data transmitted by MMA62XXKEG following reset is the Request Error message shown below. This occurs because MMA62XXKEG transmits during Phase Two and there is no corresponding Phase One for the first transfer.



#### **Figure 4-3 Request Error Frame**

### **4.1.2 Command Format**

The following abbreviations are used in the following figures.



Commands are transferred from the SPI master to MMA62XXKEG. Commands fall into three categories: acceleration data requests, register operations and device test. Acceleration data requests are initiated when bit 13 from the master is set to a logic '1' state. Register operations and device test are when bit 13 is set to logic'0' and are further distinguished by the states of bits 15 and 14.

#### **4.1.3 Acceleration Data Transfers**

Acceleration data requests are initiated when bit 15 from the master is set to a logic '0' state and bit 13 is set to a logic '1' state. The axis associated with the acceleration to be transferred is determined by  $D_{IN}$  bit 14.



**Figure 4-4 Acceleration Command Format**

Acceleration data is returned as illustrated below. In addition to the acceleration value, the axis associated with the measurement is indicated in bit 13, while bits 11 and 10 provide status information.



#### **Figure 4-6 Acceleration Command Response, Self-Test Active**

### **4.1.4 AXIS Bit**

Bit 13 indicates the axis associated with acceleration data, as shown below.

**Table 4-1 AXIS Bit Definitions**

| <b>AXIS</b> | <b>Selected Axis</b> |  |  |  |
|-------------|----------------------|--|--|--|
|             |                      |  |  |  |
|             |                      |  |  |  |

### **4.1.5 Status Bits**

Data bits 11 and 10 convey additional information regarding the acceleration data being transmitted. If an error condition is indicated, bits D9 through D0 contain flags which further describe the nature of the error.





The combination S1 = 0, S0 = 0 is never transmitted by MMA62XXKEG in response to an acceleration data command.

### **4.1.6 Acceleration Response Error Status**

Several error conditions may be detected and reported in response to an acceleration data command.



**Figure 4-7 ND/HE Error Frame**

#### **4.1.6.1 ND - No Data Available**

Bit 4 will be set to indicate a "No Data" condition if acceleration data is requested while the device is undergoing device initialization following reset. To ensure that an unexpected device reset will always be detectable regardless of the interval at which the sensor is accessed, "No Data" status will be returned in response to the first acceleration data request following device initialization.

#### **4.1.6.2 HE - Hardware Error**

A fault has been detected within the MMA62XXKEG device. Detectable fault conditions are listed below

- Device over-temperature
- Offset error
- Internal parity error

Specific error conditions are indicated in the device status register. The contents of this register are returned in response to a device test operation, as described in [Section 4.1.10](#page-23-0). Oscillator fault status will be reported only if the internal oscillator is functional but frequency comparison between the primary and reference oscillators fails. If an oscillator fault condition exists, the device will respond as described in [Section 4.2.2.2](#page-25-0).

### **4.1.6.3 CNC - Conditions Not Correct**

Acceleration data will not be provided when bit 15 of command is detected as logic '1'. The response to such requests is illustrated below. Should a No Data Available or Hardware Error condition also exist, it will be reported as well.



#### **Figure 4-8 CNC Error Frame**

### **4.1.7 Non-Acceleration Transfers**

Three different types of non-acceleration transfers are supported; register write, register read and device test. Non-acceleration data transfers are initiated when bit 13 from the master is set to a logic '0' state. The operation to be performed is indicated by bits 15 and 14.



#### **Table 4-3 Non-Acceleration Operations**

Non-acceleration transfers will always succeed except in the case of oscillator fault, SPI error or request error conditions. Only oscillator failure, SPI error or request error conditions are reported in response to non-acceleration commands. Other error condition are reported as hardware errors in response to acceleration data requests.

## **4.1.8 Register Write Operations**

Register write operations are initiated when bits 15 and 13 from the master is set to a logic '0' and bit 14 is set to a logic '1'. Bits 12 through 8 contain a five-bit address, while the last eight bits contain the data value to be written. Only the DEVCTL register is writable. If an attempt is made to write to any register other than DEVCTL, a request error response (see [Figure 4-15\)](#page-23-1) will occur.



### **Figure 4-9 Register Write Command**

Response to a register write operation is illustrated below. DEVCTL bits which can be read as logic '1' (HPFB, ST1 and ST0) will be indicated during the last eight clock cycles, as shown.



**Figure 4-10 Register Write Command Response**

## **4.1.9 Register Read Operations**

Register read operations are initiated when bit 15 from the master is set to a logic '1' state and bits 14 and 13 are driven to a logic low level. The address of the register to be accessed is contained in bits 12 through 8. D<sub>IN</sub> bits 7 through 0 are ignored by MMA62XXKEG during register read command transfers.



## **Figure 4-11 Register Read Command**

Data read from the selected register is returned in bits 7 through 0, as shown below.

![](_page_22_Figure_13.jpeg)

![](_page_22_Figure_14.jpeg)

### <span id="page-23-0"></span>**4.1.10 Device Test Operation**

A device test operation is conducted when  $D_{IN}$  bits 15 and 14 are at a logic high level and bit 13 is driven to a logic low level.

![](_page_23_Figure_2.jpeg)

#### **Figure 4-13 Device Test Command**

The content of the device status register are transmitted in bits D7 through D0 in response to a device test operation. Refer to [Section 3.1.3](#page-16-1) for details regarding the device status register

![](_page_23_Figure_5.jpeg)

#### **Figure 4-14 Device Test Command Response**

Status register bit 0 is set following any device reset. This bit will remain set until explicitly cleared by writing the CE bit in the device control register, as described in [Section 3.1.1.](#page-13-0)

#### **4.1.11 Non-Acceleration Request Error**

An error condition is indicated if a non-acceleration command is detected and  $D_{IN}$  bits 15 and 14 are both zero, as no operation is specified for this combination.

![](_page_23_Figure_10.jpeg)

**Figure 4-15 Non-Acceleration Request Error**

#### <span id="page-23-1"></span>**4.1.12 SPI Error Response**

The following conditions detected at  $D_{\text{IN}}$  will result in a SPI error. Since the error condition likely indicate a corrupted transfer, the response frame is the same regardless of the state of bit 13 at  $D_{IN}$ .

- SCLK high when CS asserted
- Fewer than 16 rising edges of SCLK detected while  $\overline{CS}$  is asserted
- Greater than 16 rising edges of SCLK detected while  $\overline{CS}$  is asserted
- SCLK high when  $\overline{\text{CS}}$  negated

The response to a SPI error condition is shown below.

![](_page_24_Figure_1.jpeg)

### **Figure 4-16 SPI Error Response**

#### **4.1.13 Initial Response**

During initialization phase one, the device does not respond to SPI access attempts. During the second initialization phase, register operations complete normally, however the device will respond to sensor data requests with No Data (ND) status. The first acceleration request following completion of device initialization will also result in a No Data response. This ensures that an unexpected reset will always be detectable, even in systems which poll the device at longer intervals than required for device initialization.

## <span id="page-24-0"></span>**4.2 ERROR CONDITIONS**

A number of error conditions may be detected. If an error condition is detected, MMA62XXKEG will always transmit an error indicator in place of acceleration data. Error indicators are defined in the following sections.

### **4.2.1 Error Condition Classification**

Error conditions fall into five classes, as described below.

#### **4.2.1.1 Critical Errors**

Error condition affects device operation. Critical errors are always reported regardless of other error conditions which may be detected.

#### **4.2.1.2 Initialization**

Initialization is a special case condition which occurs after reset until internal circuitry is ready to provide accurate acceleration results. The duration of the initialization period depends upon whether a high-pass filter has been selected or not. If no high-pass filter has been selected, initialization requires approximately 3 ms after power-up. If a high-pass filter has been selected, an additional 200 ms is required. During the device initialization period, this status is reported in response to any acceleration data request, however normal register access operations may be performed.

Device initialization status is cleared automatically.

#### **4.2.1.3 Reset**

Reset is also a special case condition. Reset will occur at power-on, as the result of a temporary undervoltage condition, or in response to explicit actions taken by the controller. Upon negation of the internal reset signal, the DEVRES flag in the device status (DEVSTAT) register is set. Because it is critically important that the system can detect any unintended reset condition, this flag may only be cleared by writing a logic '1' to the CE bit in the device control register (DEVCTL) after device initialization has completed.

### **4.2.1.4 Transient Errors**

An error condition which may be the result of a condition which precludes an accurate acceleration measurement but which may not persist. Transient errors are reported in response to acceleration data transfer requests. If a transient error condition has been detected, a logic '1' may be written to the clear error (CE) bit in the device control (DEVCTL) register to clear the associated flag. Should the error condition still exists, the flag will only be cleared momentarily.

#### **4.2.1.5 External Errors**

An error condition resulting from an invalid command input or corrupted data transfer. External errors are reported only once.

Errors are prioritized as shown in the table. In the event that multiple error conditions are detected, the highest priority error will be reported.

### **4.2.2 Error Definitions**

#### **4.2.2.1 Internal Data Error**

#### **Class: Critical error**

A parity fault has been detected in the internal data registers. In the event of a soft error (bit-flip within the register), an internal data error may be recoverable by resetting the device.

#### <span id="page-25-0"></span>**4.2.2.2 Internal Oscillator Fault**

#### **Class: Critical error**

If an oscillator fault condition is detected,  $D_{OUT}$  is driven high continuously when  $\overline{CS}$  is asserted, as illustrated below.

![](_page_25_Figure_10.jpeg)

#### **Figure 4-17 Oscillator Failure Response**

#### **4.2.2.3 Device Initialization**

#### **Class: Reset**

Following a reset condition, the device requires a period of time to complete initialization of the DSP and internal registers. If multiple SPI transfers are attempted during this initialization period, the second and all subsequent transfers will result in this status. The first transfer following reset, regardless of the state of initialization returns device reset status.

#### **4.2.2.4 Temperature Fault**

#### **Class: Transient error**

The internal temperature sensor value exceeds the allowable limits for the device.

#### **4.2.2.5 Unexpected Axis Selection**

#### **Class: External error**

An acceleration data request has been received with an axis specification which is not supported.

#### **4.2.2.6 Offset Error**

#### **Class: Transient error**

This condition exists if the output of the offset monitor circuit reaches 10% of the full-scale value and the OFMON bit is set in the DSPCFG1 register.

#### **4.2.2.7 Device Reset**

#### **Class: Reset**

Following any reset operation, the device returns this status during the first acceleration data access.

#### **4.2.2.8 SPI Clock Fault**

#### **Class: External error**

A SPI clock fault may result from the following conditions:

- The number of rising clock edges detected while CS is asserted is not equal to 16
- SCLK is high when  $\overline{\text{CS}}$  is asserted

## **4.3 ACCELERATION DATA REPRESENTATION**

Acceleration values may be determined from the 10-bit digital output (DV) as follows:

*a = sensitivity* × *DV* (signed data representation)

Sensitivity is determined by nominal full-scale range (FSR), linear range of digital values and a scaling factor to compensate for sensitivity error.

The linear range of digital values for MMA62XXKEG is limited to accommodate overrange values produced by the DSP along with two reserved end values. The linear range of digital values and signed values is from -509 to +508. Note that the ranges are asymmetrical by 1 LSB.

The sensitivity error scaling factor is determined as follows:

*scale\_factor = (100.0 - error\_tolerance) / 100.0*

Finally, the nominal sensitivity in terms of acceleration per LSB is determined:

*1 LSB = (FSR / scale\_factor) / ((Max\_Linear\_Value - Min\_Linear\_Value) / 2.0);*

For the linear ranges of digital values indicated and projected sensitivity values, the nominal value of 1 LSB for each full-scale range is shown in the table below.

![](_page_26_Picture_107.jpeg)

### **Table 4-4 Nominal Sensitivity (10-bit data)**

![](_page_27_Picture_458.jpeg)

## **Table 4-5 Nominal Signed Acceleration Data Values**

## **4.3.1 Overrange Response**

Positive acceleration levels which exceed the full-scale range of the device fall into two categories: overrange and overflow. Overrange conditions exist when the signal level is beyond the full-scale range of the device but within the computational limits of the DSP. An overflow condition occurs if the output of the low-pass filter equals or exceeds the maximum digital value which can be output from the sinc filter. Sinc filter saturation will occur before the internal datapath width is exceeded. At 25°C the sinc filter will not saturate at sustained acceleration levels with the range of ±200 g. The DSP operates predictably under all cases of overrange, 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. If an overflow condition occurs, the signal is internally clipped. The DSP will recover from an overflow condition within a few sample times after the input signal returns to the input range of the DSP. Due to internal clipping within the DSP, some high-frequency artifacts may be present in the output following an overflow condition.

For negative acceleration levels, corresponding underrange and underflow conditions are defined.

## **4.4 CAP/HOLD INPUT**

The CAP/HOLD input provides a system-level synchronization mechanism. When driven high, transfer of acceleration results from the DSP to the SPI buffers does not occur. The DSP continues its normal operation regardless of the state of CAP/HOLD. Data read from the device when CAP/HOLD is high will reflect the last values available from the DSP at the time of the signal transition.

## **SECTION 5 OPERATING MODES**

MMA62XXKEG operates in one of two modes, factory test programming mode and normal operating mode. Factory test and programming mode is entered only when certain conditions are met, and provides support for programming of customer-defined data. Normal mode is entered by default when the device is powered on.

## **5.1 NORMAL OPERATING MODE**

Normal mode is entered whenever the device is powered and the  $V_{PP}$  pin is held at or below the level of  $V_{CC}$ . In normal mode, acceleration data and device support data transfers are supported.

## **5.1.1 Power-On Reset**

Upon application of voltage at the  $V_{CC}$  pin, the internal regulators will begin driving the internal power supply rails. The C<sub>REG</sub> and  $C_{REGA}$  pins are tied to the internal rails. As voltages at  $V_{CC}$ ,  $C_{REG}$  and  $C_{REGA}$  rise, the device becomes operational. An internal reset signal is asserted at this time. Separate comparators on monitor all three voltages, and when all are above specified thresholds, the reset signal is negated and the device begins its initialization process.

## **5.1.2 Device Initialization**

Following any reset, the device completes a sequence of operations which initialize internal circuitry. Device initialization is completed in two phases. During the first phase, the fuse array is read and its contents are transferred to mirror registers. Power to the fuse array is then removed to reduce supply current load. A voltage reference used within the sensor interface stabilizes during the second phase. If the HPFSEL bit is set in the DSP configuration register (DSPCFG), the high-pass filter is also initialized during phase two.

The device will not respond to SPI accesses during initialization phase one. Acceleration results are not available during initialization phase two, however the SPI is functional and register operations may be performed. If an acceleration data access is attempted, the device will respond with non-acceleration data.

The first initialization phase requires approximately 800 μs to complete. The second phase completes in approximately 3 ms if no high-pass filter is selected, and 200 ms if the HPFSEL bit is programmed to a logic '1' state. The DEVINIT bit in the device status register (DEVSTAT) remains set following reset until the second phase of device initialization completes.

## **APPENDIX A**

| <b>Filter Option</b>     |                          |                          |                        |                      |                         | Cutoff                  |                         | Sample                     |
|--------------------------|--------------------------|--------------------------|------------------------|----------------------|-------------------------|-------------------------|-------------------------|----------------------------|
| $LPF_X[4]$<br>$LPF_Y[4]$ | $LPF_X[3]$<br>$LPF_Y[3]$ | $LPF_X[2]$<br>$LPF_Y[2]$ | $LPF_X[1]$<br>LPF_Y[1] | LPF_X[0]<br>LPF_Y[0] | Reference               | Frequency<br>$f_C$ (HZ) | Equivalent<br>Poles     | <b>Time</b><br>$t_S \mu s$ |
| 0                        | 0                        | 0                        | 0                      | 0                    | 0                       | $10$                    |                         | 256                        |
| 0                        | $\mathbf 0$              | 0                        | 0                      | $\mathbf{1}$         | $\mathbf{1}$            | 15                      |                         | 128                        |
| 0                        | $\pmb{0}$                | 0                        | $\mathbf{1}$           | $\pmb{0}$            | $\sqrt{2}$              | 30                      |                         | 64                         |
| 0                        | $\pmb{0}$                | $\pmb{0}$                | $\mathbf{1}$           | $\mathbf{1}$         | 3                       | 50                      |                         |                            |
| $\mathbf 0$              | $\pmb{0}$                | $\mathbf{1}$             | 0                      | 0                    | $\overline{\mathbf{4}}$ | 75                      |                         | 32                         |
| 0                        | $\pmb{0}$                | $\mathbf{1}$             | 0                      | $\mathbf{1}$         | 5                       | 100                     |                         |                            |
| $\mathbf 0$              | $\mathbf 0$              | $\mathbf{1}$             | $\mathbf{1}$           | 0                    | 6                       | 130                     |                         |                            |
| 0                        | $\pmb{0}$                | $\mathbf{1}$             | $\mathbf{1}$           | $\mathbf{1}$         | $\overline{7}$          | 160                     |                         |                            |
| 0                        | $\mathbf{1}$             | $\pmb{0}$                | 0                      | $\pmb{0}$            | 8                       | 200                     |                         | 16                         |
| 0                        | $\mathbf{1}$             | 0                        | $\mathbf 0$            | $\mathbf{1}$         | $\boldsymbol{9}$        | 250                     | $\overline{\mathbf{4}}$ |                            |
| 0                        | $\mathbf{1}$             | 0                        | $\mathbf{1}$           | $\pmb{0}$            | 10                      | 300                     |                         |                            |
| $\mathsf 0$              | $\mathbf{1}$             | $\pmb{0}$                | $\mathbf{1}$           | $\mathbf{1}$         | 11                      | 350                     |                         |                            |
| 0                        | $\mathbf{1}$             | $\mathbf{1}$             | $\pmb{0}$              | 0                    | 12                      | 400                     |                         |                            |
| 0                        | $\mathbf{1}$             | $\mathbf{1}$             | $\pmb{0}$              | $\mathbf{1}$         | 13                      | 500                     |                         |                            |
| $\mathbf 0$              | $\mathbf{1}$             | $\mathbf{1}$             | $\mathbf{1}$           | 0                    | 14                      | 600                     |                         |                            |
| 0                        | $\mathbf{1}$             | $\mathbf{1}$             | $\mathbf{1}$           | $\mathbf{1}$         | 15                      | 700                     |                         |                            |
| $\mathbf{1}$             | $\pmb{0}$                | 0                        | 0                      | 0                    | 16                      | 800                     |                         |                            |
| $\mathbf{1}$             | $\pmb{0}$                | 0                        | $\pmb{0}$              | $\mathbf{1}$         | 17                      | 900                     |                         |                            |
| 1                        | $\pmb{0}$                | $\pmb{0}$                | $\mathbf{1}$           | $\mathbf 0$          | 18                      | 1000                    |                         |                            |
| $\mathbf{1}$             | $\pmb{0}$                | 0                        | $\mathbf{1}$           | $\mathbf{1}$         | 19                      | 10                      |                         | 64                         |
| $\mathbf{1}$             | $\pmb{0}$                | $\mathbf{1}$             | $\mathbf 0$            | $\pmb{0}$            | 20                      | 15                      |                         |                            |
| $\mathbf{1}$             | $\mathbf 0$              | $\mathbf{1}$             | 0                      | $\mathbf{1}$         | 21                      | 30                      |                         | 32                         |
| $\mathbf{1}$             | $\pmb{0}$                | $\mathbf{1}$             | $\mathbf{1}$           | 0                    | 22                      | 50                      |                         |                            |
| $\mathbf{1}$             | $\pmb{0}$                | $\mathbf{1}$             | $\mathbf{1}$           | $\mathbf{1}$         | 23                      | 75                      |                         |                            |
| $\mathbf{1}$             | $\mathbf{1}$             | $\pmb{0}$                | 0                      | $\pmb{0}$            | 24                      | 100                     |                         |                            |
| $\mathbf{1}$             | $\mathbf{1}$             | 0                        | 0                      | $\mathbf{1}$         | 25                      | 130                     | $\mathbf 2$             |                            |
| $\mathbf{1}$             | $\mathbf{1}$             | 0                        | $\mathbf{1}$           | $\pmb{0}$            | 26                      | 160                     |                         | 16                         |
| $\mathbf{1}$             | $\mathbf{1}$             | 0                        | $\mathbf{1}$           | $\mathbf{1}$         | 27                      | 200                     |                         |                            |
| $\mathbf{1}$             | $\mathbf{1}$             | $\mathbf{1}$             | $\pmb{0}$              | $\pmb{0}$            | 28                      | 250                     |                         |                            |
| $\mathbf{1}$             | $\mathbf{1}$             | $\mathbf{1}$             | 0                      | $\mathbf{1}$         | 29                      | 300                     |                         |                            |
| $\mathbf{1}$             | $\mathbf{1}$             | $\mathbf{1}$             | 1                      | $\pmb{0}$            | 30                      | 350                     |                         |                            |
| $\mathbf{1}$             | $\mathbf{1}$             | $\mathbf{1}$             | $\mathbf{1}$           | $\mathbf{1}$         | 31                      | 400                     |                         |                            |

**Table A-1: Low-Pass Filter Options**

![](_page_31_Figure_1.jpeg)

![](_page_31_Picture_60.jpeg)

NOTES:

- 1. DIMENSIONING AND TOLERANCING PER ASME Y14.5M-1994.
- 2. DIMENSIONS ARE IN MILLIMETERS.
- $\sqrt{3}$  This dimension do not include mold protrusion.
- 4. MAXIMUM MOLD PROTRUSION 0.15(0.006) PER SIDE.
- $\frac{1}{2}$  This dimension does not include dam bar protrusion allowable dam bar PROTRUSION SHALL BE 0.13(0.005) TOTAL IN EXCESS OF THIS DIMENSION AT MAXIMUM MATERIAL CONDITION.

![](_page_32_Picture_45.jpeg)

#### *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. All other product or service names are the property of their respective owners. © Freescale Semiconductor, Inc. 2009. 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.

![](_page_33_Picture_19.jpeg)

MMA6222KEG Rev. 0 12/2009