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

# Programmable High-g Digital Impact Sensor and Recorder

# ADIS16204

#### **FEATURES**

**Dual-axis sensing, ±70 g, ±37 g 14-bit resolution Impact peak-level sample-and-hold RSS output Programmable event recorder 400 Hz double-pole Bessel sensor response Digitally controlled sensitivity and bias Digitally controlled sample rate, up to 4096 SPS Programmable condition monitoring alarms Auxiliary digital I/O Digitally activated self-test Embedded temperature sensor Programmable power management SPI-compatible serial interface Auxiliary 12-bit ADC input and DAC output Single-supply operation: +3.0 V to +3.6 V 4000 g powered shock survivability** 

#### **APPLICATIONS**

**Crash or impact detection Condition monitoring of valuable goods Safety, shut-off sensing Impact event recording Security sensing, tamper detection** 

### **GENERAL DESCRIPTION**

The ADIS16204 is a fully-contained programmable impact sensor in a single compact package enabled by the Analog Devices, Inc. iSensor™ integration. By enhancing the Analog Devices iMEMS® sensor technology with an embedded signal processing solution, the ADIS16204 provides tunable digital sensor data in a convenient format that can be accessed using a serial peripheral interface (SPI). The SPI provides access to measurements for dual-axis linear acceleration, a root sum square (RSS) of both axes, temperature, power supply, an auxiliary analog input, and an event capture buffer memory. Easy access to digital sensor data provides users with a system-ready device, reducing development time, cost, and program risk. **Example and the set sensor of the set sensor of the processes and the set sensor of the set sensor and the confidence of the set of t** 

Unique characteristics of the end system are accommodated easily through several built-in features, such as a single command in-system bias null/offset calibration, along with convenient sample rate control.

### **FUNCTIONAL BLOCK DIAGRAM**



The ADIS16204 offers the following embedded features, which eliminate the need for external circuitry and provide a simplified system interface:

- Peak sample-and-hold
- Programmable event recording (dual,  $1K \times 16$  bit)
- RSS output (total shock in the XY plane)
- Configurable alarms
- Auxiliary 12-bit ADC and DAC
- Configurable digital I/O port
- Digital self-test function

The ADIS16204 offers two power management features for managing system-level power dissipation: low power mode and a configurable shutdown feature.

The ADIS16204 is available in a 9.2 mm  $\times$  9.2 mm  $\times$  3.9 mm laminate-based land grid array (LGA) package with a temperature range of −40°C to +105°C.

#### **Rev. B**

**Information furnished by Analog Devices is believed to be accurate and reliable. However, no responsibility is assumed by Analog Devices for its use, nor for any infringements of patents or other rights of third parties that may result from its use. Specifications subject to change without notice. No license is granted by implication or otherwise under any patent or patent rights of Analog Devices. Trademarks and registered trademarks are the property of their respective owners.** 

**One Technology Way, P.O. Box 9106, Norwood, MA 02062-9106, U.S.A. Tel: 781.329.4700 www.analog.com Fax: 781.461.3113 ©2007–2009 Analog Devices, Inc. All rights reserved.** 

## **TABLE OF CONTENTS**



### **REVISION HISTORY**



10/07-Rev. 0 to Rev. A



### 6/07-Revision 0: Initial Version



## <span id="page-2-0"></span>**SPECIFICATIONS**

T<sub>A</sub> =  $-40^{\circ}$ C to +105°C, VDD = 3.3 V, unless otherwise noted.

### **Table 1.**



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

1 Note that gravity can impact this number; zero-*g* condition assumes both axes oriented normal to the earth's gravity.

<sup>2</sup> Self-test response changes as the square of VDD.<br><sup>3</sup> Note that the inputs are +5 V tolerant.

<sup>4</sup> Guaranteed by design.

<sup>5</sup> Endurance is qualified as per JEDEC Standard 22, Method A117 and measured at −40°C, +25°C, +85°C, and +105°C. 6

### <span id="page-4-3"></span><span id="page-4-0"></span>**TIMING SPECIFICATIONS**

T<sub>A</sub> = +25°C, V<sub>cc</sub> = +3.3 V, unless otherwise noted.

#### **Table 2.**



1 Guaranteed by design; typical specifications are not tested or guaranteed. 2 Based on sample rate selection.

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



## <span id="page-5-0"></span>ABSOLUTE MAXIMUM RATINGS

#### **Table 3.**



Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; functional operation of the device at these or any other conditions above those indicated in the operational section of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. sture Range<br> **OBSOC CO-1125°C**<br>
The Range<br>
Se listed under Absolute Maximum Ratings<br>
se histed under Absolute Maximum Ratings<br>
box those indicates at these or any<br>
construction is not implied. Exprosure to absolute<br>
condit

#### **ESD CAUTION**



ESD (electrostatic discharge) sensitive device. Charged devices and circuit boards can discharge without detection. Although this product features patented or proprietary protection circuitry, damage may occur on devices subjected to high energy ESD. Therefore, proper ESD precautions should be taken to avoid performance degradation or loss of functionality.

## <span id="page-6-1"></span><span id="page-6-0"></span>PIN CONFIGURATION AND FUNCTION DESCRIPTIONS



**Table 4. Pin Function Descriptions** 



 $1 S =$  supply; O = output; I = input.

### **RECOMMENDED PAD GEOMETRY**



**9.2mm × 9.2mm STACKED LGA PACKAGE**

*Figure 5. Example of a Pad Layout*

## <span id="page-7-0"></span>TYPICAL PERFORMANCE CHARACTERISTICS







*Figure 14. Sleep Current vs. Temperature* 

## <span id="page-9-1"></span><span id="page-9-0"></span>THEORY OF OPERATION

### **OVERVIEW**

The ADIS16204 integrates a dual-axis  $\pm$ 70 g/ $\pm$ 37 g MEMS acceleration sensor into a complete impact/shock measurement and recording system. The integrated mixed signal processing circuit digitizes the sensor data, applies corrections factors, provides many user-programmable features, and offers a simple communication conduit: the serial peripheral interface (SPI).

### **ACCELERATION SENSOR**

The ADIS16204 base sensor core provides a fully differential sensor structure and circuit path, resulting in substantial rejection of electromagnetic interference (EMI) effects. It uses electrical feedback with zero-force feedback for improved accuracy and stability. The sensor's resonant frequency is well beyond the cut-off frequency of the filter, which adds further noise rejection to the sensor signal conditioning circuit.



*Figure 17. Simplified View of a Sensor Under Acceleration* 

<span id="page-9-3"></span><span id="page-9-2"></span>[Figure 17](#page-9-2) is a simplified view of one of the differential sensor elements. Each sensor includes several differential capacitor unit cells. Each cell is composed of fixed plates attached to the substrate and movable plates attached to the frame. Displacement of the frame changes the differential capacitance, which is measured by the on-chip circuitry.

Complementary 200 kHz square waves drive the fixed plates. Electrical feedback adjusts the amplitudes of the square waves such that the ac signal on the moving plates is 0 V. The feedback signal is linearly proportional to the applied acceleration. This unique feedback technique ensures that there is no net electrostatic force applied to the sensor. The differential feedback control signal is also applied to the input of the filter, where it is filtered and converted to a single-ended signal.

### <span id="page-9-4"></span>**TEMPERATURE SENSOR**

This sensor reflects the sensor's junction temperature and provides a convenient temperature measurement for systemlevel characterization and calibration feedback.

### **IMPACT/SHOCK RESPONSE**

The sensor's mechanical structure provides a linear measurement range that is 8 times that of each axis' actual output measurement range. Therefore, when considering the response to high-g, short duration events, the 2-pole, 400 Hz, low-pass Bessel filter network influences the output response. [Figure 18](#page-9-3)  provides a frequency response for this signal chain. In [Figure 19](#page-9-4), the X-axis accelerometer experiences a 560 g shock event that lasts 0.1 ms, causing the output response to reach 70 g. For users that need to avoid output saturation, keeping the integration of the event's acceleration response (acceleration-time product in the case of Figure 19) below 56 g-ms is critical.



### <span id="page-10-0"></span>**AUXILIARY ADC FUNCTION**

<span id="page-10-1"></span>The auxiliary ADC function integrates a standard 12-bit ADC into the ADIS16204 to digitize other system-level analog signals. The output of the ADC can be monitored through the AUX\_ADC control register, as defined in [Table 6](#page-12-1). The ADC is a 12-bit successive approximation converter. The output data is presented in straight binary format with the full-scale range extending from 0 V to  $V_{REF}$ . A high precision, low drift, factory calibrated 2.5 V reference is also provided.

[Figure 20](#page-10-1) shows the equivalent circuit of the analog input structure of the ADC. The input capacitor (C1) is typically 4 pF and can be attributed to parasitic package capacitance. The two diodes provide ESD protection for the analog input. Care must be taken to ensure that the analog input signals never exceed the supply rails by more than 300 mV. This causes the diodes to become forward-biased and to start conducting. The diodes can handle 10 mA without causing irreversible damage. The resistor is a lumped component that represents the on resistance of the switches. The value of this resistance is typically 100  $\Omega$ . Capacitor C2 represents the ADC sampling capacitor and is typically 16 pF. was the equivalent circuit of the analog input pin.<br>
Yo. The input capacitor (C1) is typically 4 pF and<br>
talo parasitic package capacitance. The two diodes<br>
ratio are critical, the analog input most be drived<br>
ratio are re



*Conversion Phase: Switch Open Track Phase: Switch Closed* 

For ac applications, removing high frequency components from the analog input signal is recommended by the use of a low-pass filter on the analog input pin.

In applications where harmonic distortion and signal-to-noise ratio are critical, the analog input must be driven from a low impedance source. Large source impedances significantly affect the ac performance of the ADC. This can necessitate the use of an input buffer amplifier. When no input amplifier is used to drive the analog input, the source impedance should be limited to

## <span id="page-11-1"></span><span id="page-11-0"></span>BASIC OPERATION

The ADIS16204 is designed for simple integration into industrial system designs, requiring only a power supply and a 4-wire, industry-standard SPI. The SPI provides access to the ADIS16204's register structure, which controls access to all sensor output data and controls for the device's programmable features. Each register is 16 bits in length and has its own unique bit map. The 16 bits in each register consist of an upper byte (Bit 8 to Bit 15) and a lower byte (Bit 0 to Bit 7), each of which has its own 6-bit address.

### **SERIAL PERIPHERAL INTERFACE**

The ADIS16204 SPI port includes four signals: chip select (CS), serial clock (SCLK), data input (DIN), and data output (DOUT). The CS line enables the ADIS16204 SPI port and frames each SPI event. When this signal is high, the DOUT lines are in a high impedance state and the signals on DIN and SCLK have no impact on operation. A complete data frame contains 16 clock cycles. Because the SPI port operates in full duplex mode, it supports simultaneous, 16-bit receive (DIN) and transmit (DOUT) functions during the same data frame.

<span id="page-11-3"></span><span id="page-11-2"></span>Se[e Table 2,](#page-4-3) [Figure 2](#page-4-1), and Figure 3 for detailed timing and operation of the SPI port.

### **Writing to Registers**

[Figure 21](#page-11-2) displays a typical data frame for writing a command to a control register. In this case, the first bit of the DIN sequence is a 1, followed by a 0, the 6-bit address, and the 8-bit data command. Because each write command covers a single byte of data, two data frames are required when writing to the entire 16-bit space of a register. The DIN bits clock into the ADIS16204 on the rising edge of SCLK.

### **Reading from Registers**

Reading the contents of a register requires a modification to the sequence in the DIN sequence shown in [Figure 21.](#page-11-2) As shown in Figure 22, the first two bits in the DIN sequence are 0, followed by 6 address bits. Each register has two addresses (upper, lower), but either one can be used to access its entire 16 bits of data. The final 8 bits of the DIN sequence are irrelevant and can be counted as don't cares during a read command. During the next data frame, the DOUT sequence contains the register's 16-bit data. The ADIS16204 clocks out the first DOUT bit on the falling edge of the CS line and clocks out the rest of the DOUT bits on the falling edges of the SCLK signal. Although a single read command requires two separate data frames, the full duplex mode minimizes this overhead, requiring only one extra data frame when continuously sampling.



### <span id="page-12-3"></span><span id="page-12-0"></span>**DATA OUTPUT REGISTER ACCESS**

[Table 6](#page-12-1) provides an overview of each data output register, along with their function, address, and relevant decoding information.

#### **Sensor Output Data**

The ADIS16204 provides access to X- and Y-axis acceleration measurements, combined accelerations measurements (root sum square of X and Y), peak acceleration, power supply measurements, temperature measurements, an auxiliary 12-bit ADC channel, and the event-capture buffer memory.

#### **Peak Sample-and-Hold Output Registers**

The ADIS16204 monitors the X, Y and XY acceleration measurements and holds the maximum value and polarity for each parameter. The X\_PEAK\_OUT, Y\_PEAK\_OUT, and XY\_PEAK\_OUT registers provide access to these maximum values. See the COMMAND register for how to clear these registers.

#### **Register Access**

This output data is continuously updating internally, regardless of user read rates. The bit map in Table 5 describes the structure of

#### <span id="page-12-1"></span>**Table 6. Data Output Register Information**

all output data registers in the ADIS16204. The upper byte is always first in register read sequences.

#### **Table 5. Output Bit Assignments**



The MSB holds the new data (ND) indicator. When the output registers are updated with new data, the ND bit goes to a 1 state. After the output data is read, it returns to a 0 state. The error/ alarm bit (EA) is used to indicate a system error or an alarm condition that can result from a number of conditions, such as a power supply that is out of the specified operating range (see the Status and Diagnostics section for more details). The output data is either 12 bits or 14 bits in length. For all of the 12-bit output data, Bit D13 and Bit D12 are assigned don't care status.

The output data register map located in Table 6 provides all of the necessary details for accessing each register's data. [Figure 23](#page-12-2)  provides an example of the SPI sequence.



<sup>1</sup> 25°C, nominal output is equal to 1278 LSB.

2 The peak levels in these registers accumulate, storing the greatest value measured (polarity is captured—except for XY\_PEAK\_OUT), until they are cleared using the COMMAND register.

<sup>3</sup> This is a measure of the total shock absorbed by the package in the XY plane, and is the result of a root sum square of X and Y acceleration measurements.

<span id="page-12-2"></span>4 See the Alarm Detection and Event Capture section for more details.



*Figure 23. Example of an Output Timing/Coding Diagram* 

## <span id="page-13-1"></span><span id="page-13-0"></span>PROGRAMMING AND CONTROL

## **CONTROL REGISTER OVERVIEW**

The ADIS16204 offers many programmable features controlled by writing commands to the appropriate control registers. The following features are available for configuration:

- Global commands
- Calibration
- Operational control
	- Sample rate
	- Power management
	- DAC output
	- Digital I/O
- Operational status and diagnostics
	- Self-test
	- Status conditions
	- Alarms
- Event capture

#### <span id="page-13-2"></span>**Table 7. Control Register Mapping**

### **CONTROL REGISTER STRUCTURE**

The ADIS16204 uses a temporary, SRAM-based memory structure to facilitate the control registers displayed in [Table 7](#page-13-2). The start-up configuration is stored in a flash memory structure that automatically loads into the control registers during the start-up sequence. Each nonvolatile register has a corresponding flash memory location for storing the latest configuration contents. Because flash memory has endurance limitations, the contents of each nonvolatile register must be stored to flash manually. Note that the contents of the control register are only nonvolatile when they are stored to flash. The flash update command, made available in the COMMAND register, provides this function. The ENDURANCE register provides a counter, which allows for memory reliability management against the flash memory's write cycle specification.



<sup>1</sup> In order to establish nonvolatile status, the flash memory must be updated after updating the control registers.

<sup>2</sup> Bit 8 clears after the internal self-test sequence completes, effectively making this bit volatile.

### <span id="page-14-1"></span><span id="page-14-0"></span>**GLOBAL COMMANDS**

<span id="page-14-5"></span>The ADIS16204 provides global commands, which simplify many common operations. The COMMAND register provides command bits for each function. Writing a 1 to the assigned command bit exercises its function. The flash update copies the contents of all nonvolatile registers into their assigned, nonvolatile, flash memory locations. This process takes approximately 50 ms and requires a power supply that is within the specified operating range. After waiting the appropriate time for the flash update to complete, verify successful completion by reading the STATUS register (flash update error = zero, if successful). If the flash update was not successful, reading this error bit accomplishes two things: (1) alert system processor to try again, and (2) clear the error flag, which is required for flash memory access.

<span id="page-14-6"></span>The software reset command restarts the internal processor, which loads all registers with the contents in their flash memory locations. The DAC data latch command loads the contents of AUX\_DAC into the DAC latches. Because the AUX\_DAC contents must be updated one byte at a time, this command ensures a stable DAC output voltage during updates.

#### **Calibration Commands**

The autonull command provides a simple method for removing offset from the sensor outputs. This command takes separate 64-sample measurements for each axis (X, Y), then loads the opposite value into each axis' offset null register. The accuracy of this operation depends on zero force or motion during the 64-sample timeframe. The factory calibration restore sets the scale and offset null registers (XACCL\_NULL, for example) back to their default values. For more information on ADIS16204 calibration, see the Calibration section.

#### **Event Capture Commands**

The COMMAND register provides four different functions that simplify the process of using the event capture function. The reset-capture pointer function sets the contents of the capture pointer to its initial value of 0x0001. The clear capture flash, clear capture buffer, and capture flash copy commands are selfdescriptive. The capture flash copy takes approximately 120 ms to complete and serves the purpose of copying the capture buffer into nonvolatile flash memory. See the Alarm Detection and [Event Capture](#page-17-1) section for more information. Ly sectes the computer of the state of the computer of the computer of the state of the sta

#### **Table 8. COMMAND Register Definition**

<span id="page-14-4"></span><span id="page-14-3"></span><span id="page-14-2"></span>





#### **CALIBRATION**

In addition to the factory calibration, the ADIS16204 provides a user configurable calibration for systems that require accuracy improvements. For example, a vehicle system may require better resolution to separate a minor bump from a hard brake event. In cases like this, the ADIS16204 provides configuration registers that adjust both offset and sensitivity (gain) on both X- and Y-axes. The following relationship describes the calibration function:

 $y = mx + b$ 

where:

y is the calibrated output data.

m is the scale factor multiplier [XACCL\_SCALE/YACCL\_SCALE].  $x$  is the precalibration data.

b is the offset adder [XACCL\_NULL/YACCL\_NULL].

Assuming zero offset and nominal scale factor (sensitivity), the offset adjustment range for the X-axis is  $\pm$ 35.054 g and  $\pm$ 17.527 g for the Y-axis. Assuming zero offset, the scale factor adjustment range is 0 to 2.

#### **Table 10. XACCL\_NULL Register Definition**



<sup>1</sup> Scale is the weight of each LSB.

#### **Table 11. YACCL\_NULL Register Definition**



1 Scale is the weight of each LSB.

#### **Table 12. XACCL\_SCALE Register Definition**



<sup>1</sup> Scale is the weight of each LSB.

2 Equates to a scale factor of one.

#### <span id="page-15-0"></span>**Table 13. YACCL\_SCALE Register Definition**

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

1 Scale is the weight of each LSB.

2 Equates to a scale factor of one.

#### **Table 14. Calibration Register Bit Descriptions**



### **OPERATIONAL CONTROL**

#### **Internal Sample Rate**

The internal sample rate defines how often data output variables are updated, independent of the rate at which they are read out on the SPI port. The SMPL\_PRD register controls the ADIS16204 internal sample rate and has two parts: a selectable time base and a multiplier. The following relationship produces the sample rate:

 $T_S = T_B \times (N_S + 1)$ 

where:

 $T<sub>s</sub>$  is the sample period.

 $T_B$  is the time base.

 $N<sub>s</sub>$  is the increment setting.

The default value is the maximum 4096 SPS, and the contents of this register are nonvolatile.

#### **Table 15. SMPL\_PRD Register Definition**



#### **Table 16. SMPL\_PRD Bit Descriptions**

<span id="page-15-4"></span>

Here is an example calculation of the sample period for the ADIS16204:

If  $SMPI\_PRD = 0x0007, B7 - B0 = 00000111$ 

 $BZ = 0 \rightarrow T_B = 122.07$  μs

$$
B6...B0 = 000000111 \Rightarrow N_S = 7
$$

$$
T_s = T_B \times (N_s + 1) = 122.07 \text{ }\mu\text{s} \times (7 + 1) = 976.56 \text{ }\mu\text{s}
$$

$$
f_s = 1/T_s = 1024
$$
SPS

<span id="page-15-3"></span><span id="page-15-2"></span>The sample rate setting has a direct impact on the SPI data rate capability. For sample rates ≥1024 SPS, the SPI SCLK can run at a rate up to 2.5 MHz. For sample rates <1024 SPS, the SPI SCLK can run at a rate up to 1 MHz.

The sample rate setting also affects the power dissipation. When the sample rate is set below 1024 SPS, the power dissipation typically reduces by a factor of 68%. The two different modes of operation offer a system-level trade-off between performance (sample rate, serial transfer rate) and power dissipation.

#### **Power Management**

In addition to offering two different performance modes for power optimization, the ADIS16204 offers a programmable shutdown period. Writing the appropriate sleep time to the SLP\_CNT register shuts the device down for the specified time. The following example provides an illustration of this relationship:

 $B7...$   $B0 = 00000110$ 

Sleep period  $=$  3 seconds

After completing the sleep period, the ADIS16204 returns to normal operation.

#### **Table 17. SLP\_CNT Register Definition**



1 Scale is the weight of each LSB.

#### **Table 18. SLP\_CNT Bit Descriptions**



#### **Auxiliary DAC**

The auxiliary DAC provides a 12-bit level adjustment function. The AUX\_DAC register controls the operation of this feature. It offers a rail-to-rail buffered output that has a range of 0 V to 2.5 V. The DAC can drive its output to within 5 mV of the ground reference when it is not sinking current. As the output approaches ground, the linearity begins to degrade (100 LSB beginning point). As the sink current increases, the nonlinear range increases. The DAC output latch function, contained in the COMMAND register, provides continuous operation while writing to each byte of this register. The contents of this register are volatile, which means that the desired output level must be set after every reset and power cycle event. **CONTROL**<br>
Surface the state of the state center of the rate defines how often data output variables<br>
Surface the state of the state of the ADISI6204<br>
Surfa

#### **Table 19. AUX\_DAC Register Definition**



<sup>1</sup> Scale is the weight of each LSB. In this case, it represents 4095 codes over the 2.5 V range out of output voltage.

#### **Table 20. AUX\_DAC Bit Descriptions**



### <span id="page-16-0"></span>**General-Purpose I/O**

The ADIS16204 provides two general-purpose pins that enable digital I/O control using the SPI. The GPIO\_CTRL control register establishes the configuration of these pins and handles the SPI-to-pin controls. Each pin provides the flexibility of both input (read) and output (write) operations. For example, writing a 0x0202 to this register establishes Line 1 as an input and Line 2 as an output that is in a 1 state. Writing 0x0000 to this register establishes both lines as inputs. When one (or both) of these lines is configured as an input, reading the assigned bit (Bit 8 and/or Bit 9) provides access to the input on this input pin.

The digital I/O lines are also available for data-ready and alarm/ error indications. In the event of conflict, the following priority structure governs the digital I/O configuration:

- 1. GPIO\_CTRL
- 2. MSC\_CTRL
- 3. ALM\_CTRL

#### <span id="page-16-5"></span><span id="page-16-4"></span><span id="page-16-3"></span>**Table 21. GPIO\_CTRL Register Definition**



### <span id="page-16-1"></span>**STATUS AND DIAGNOSTICS**

The ADIS16204 provides a number of status and diagnostic functions. [Table 23](#page-16-6) provides a summary of these functions, along with their appropriate control registers.

#### **Table 23. Status and Diagnostic Functions**

<span id="page-16-6"></span>

#### <span id="page-16-2"></span>**Data-Ready I/O Indicator**

The data-ready function provides an indication of new output data. The MSC\_CTRL register provides the opportunity to configure either of the general-purpose I/O pins (DIO1 and DIO2) as a data-ready indicator signal. When configured as a data ready indicator, the duty cycle is 20% (±10% tolerance).

#### **Self-Test**

The MSC\_CTRL register also provides a self-test function that verifies the mechanical integrity of the MEMS sensor. A self-test exercises the mechanical structure and signal conditioning circuit: from sensor element to data out. The internal test provides a simple, two-step process for checking the MEMS sensor: (1) start the process by writing a 1 to Bit 8 in the MSC\_CTRL register, (2) wait 35 ms, and (3) check the result by reading Bit 5 of the STATUS register.

The device is configured to perform a self-test at power on. Writing a 1 to Bit 10 of the MSC\_CTRL register disables this function for future start-up sequences, reducing the start-up time. For reference, the result of the electrostatic deflection of each axis is available by reading the XACCL\_OUT and/or YACCL\_OUT registers. As an additional indicator of self-test, the new data bit is not active while in this mode.

### **Table 24. MSC\_CTRL Register Definition**



#### **Table 25. MSC\_CTRL Bit Descriptions**



#### **Flash Memory Endurance**

The ENDURANCE register maintains a running count of writes to the flash memory. This provides a convenient tool for managing the reliability of the on-chip memory. Once it reaches its maximum value of 32,767, it wraps around to zero and starts over.

#### **Table 26. ENDURANCE Register Definition**



### <span id="page-17-0"></span>**STATUS Conditions**

The STATUS register contains the following error-condition flags: alarm conditions, self-test status, SPI communication failure, capture buffer full, control register update failure, and power supply out of range. See Table 27 and [Table 28](#page-17-2) for the appropriate register access and bit assignment for each flag. The bits assigned for checking power supply range automatically reset to zero when the error condition no longer exists. Clearing the remaining error-flag bits requires a single write command to the COMMAND register (write a 1 to Bit 4). See [Table 8](#page-14-4) and [Table 9](#page-14-5) for the configuration details of the COMMAND register. If the error condition still exists after exercising the COMMAND register to clear the bits, the appropriate error flag bit returns to 1 during the next sampling cycle. All bits in the STATUS register are volatile.

#### **Table 27. STATUS Register Definition**



#### <span id="page-17-2"></span>**Table 28. STATUS Bit Descriptions**



### <span id="page-17-1"></span>**ALARM DETECTION AND EVENT CAPTURE**

The ADIS16204 provides alarm detection and event capture functions, which monitor critical internal and external operating conditions. Six factory standard alarms monitor the AIDS16204 for normal operation. Two programmable alarms provide monitoring for system-critical conditions,

which reduces the external processing burden for this function. Alarm monitoring includes both software (STATUS register) and hardware options (DIO1 and DIO2 configuration, ALM\_CTRL register). In addition, the programmable alarms can trigger an event capture function, which provides time recording, much like a single event capture function on a digital oscilloscope. [Table 29](#page-18-5) provides a summary of the functions available for configuring the alarms.

#### **Alarm Configuration**

#### **1. Program the Output Data to Monitor.**

Essentially, this establishes the trigger source, by configuring the upper byte of the ALM\_CTRL register. See [Table 31](#page-18-4) for the proper bit assignments. For example, the following pseudo code establishes X acceleration as the trigger for Alarm 2 and Y acceleration as the trigger for Alarm 1:

Write 0x23 to Address 0x29 [ALM\_CTRL].

#### **2. Program the Trigger Levels and Polarity.**

This requires two write commands for each alarm, to the ALM\_MAG1 and ALM\_MAG2 registers. For example, use the following pseudo code to establish greater than 7.4  $g$  as the trigger threshold for both channels:

- Write 0x81 to Address 0x21 [ALM\_MAG1].
- Write 0xB0 to Address 0x20 [ALM\_MAG1].
- Write 0x83 to Address 0x23 [ALM\_MAG2].
- Write 0x70 to Address 0x22 [ALM\_MAG2].

The ALM\_MAG1 and ALM\_MAG2 values are calculated by:

- $X = 7.4$  g = 432 codes = 00 0001 1011 0000 (Bit 0 to Bit 13)
- $Y = 7.4 g = 880 \text{ codes} = 00 0011 0111 0000$  (Bit 0 to Bit 13)

Bit 15 in both registers must be set to 1 in order to denote greater than polarity.

#### **3. Set Up a Digital I/O Line as an Alarm Indicator.**

This step requires configuration of the lower byte in the ALM\_CTRL. If software monitoring, using the STATUS register, is the preferred alarm-checking method, then this step is not required. The following pseudocode establishes Digital I/O Line 2 as a positive signal, alarm indicator:

Write 0x07 to Address 0x28 [ALM\_CTRL].

See [Table 31](#page-18-4) for the configuration options available for this function. As noted earlier, the digital I/O lines are shared, so use of them as an alarm indicator requires that it not be in use as a data-ready or general-purpose I/O pin.

<span id="page-18-5"></span><span id="page-18-2"></span><span id="page-18-1"></span>

#### **Table 29. Alarm and Event Capture Configuration Registers**

#### **Table 30. ALM\_CTRL Register Definition**

<span id="page-18-3"></span>

## <span id="page-18-6"></span><span id="page-18-4"></span>**Table 31. ALM\_CTRL Bit Descriptions Bit Value Description**



#### **Table 32. ALM\_MAG1 Register Definition**

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





#### **Table 34. ALM\_MAG1/ALM\_MAG 2 Bit Designations**



### **Event Capture Overview**

The ADIS16204 also provides a dual-channel, capture function. Figure 24 provides an example of a captured waveform. A dedicated set of programmable control registers govern the operation of this function, controlling the data source: trigger settings (level, direction, and data source), memory depth, pretrigger data length, and data storage. In systems that require specific event monitoring, this feature simplifies system integration by reducing the burden on the system's processor. One convenient feature is the fact that the trigger source does not have to be the data that is captured.



## **Event Capture Configuration**

The event capture buffers use the alarms as their trigger source. Therefore, the first two configuration steps are the same. After setting the trigger data source(s) and threshold(s), follow Step 1 through Step 5 to complete the event capture setup.

#### **1. Program the Data Source to Capture.**

This requires a single write cycle, to configure the upper byte of the CAPT\_CFG register. For example, use the following pseudo code to set X acceleration and Y acceleration as the data sources for Capture Buffer 2 and Capture Buffer 1 respectively:

Write 0x23 to Address 0x39 [CAPT\_CFG].

#### <span id="page-19-1"></span>**2. Configure the Capture Backup Memory.**

Setting Bit 11 of the MSC\_CTRL register to a 1 enables the event capture back-up function, effectively making it nonvolatile. When enabled, this function copies the contents of the capture buffer (right after it fills) to flash memory and restores it upon reset or powering the device on. It continues to do so until the buffer is cleared, using the COMMAND register. To enable this feature, use the following pseudo code:

Write 0x08 to Address 0x35 [MSC\_CTRL].

#### **3. Clear the Capture Memory Locations.**

Use the following pseudo code to clear both the normal capture locations (SRAM) and their respective flash memory locations:

- Write 0x03 to Address 0x3F [COMMAND].
- **4. Set Up a Digital I/O Line as an Alarm Indicator.**

#### **5. Set Each Alarm as a Trigger Source for the Buffer.**

These steps require configuration of the lower byte in the ALM\_CTRL register. The following pseudo code establishes Digital I/O Line 2 as a positive signal, alarm indicator, if necessary. It also arms both triggers for the event recorder.

Write 0x57 to Address 0x28 [ALM\_CTRL].

If a digital alarm indicator function were not required, the pseudo code would be:

Write 0x50 to Address 0x28 [ALM\_CTRL].

#### <span id="page-19-5"></span>**Table 35. CAPT\_CFG Register Definition**



#### **Table 36. CAPT\_CFG Bit Descriptions**

<span id="page-19-4"></span><span id="page-19-3"></span><span id="page-19-2"></span><span id="page-19-0"></span>

#### **Event Capture Data Access**

Two output registers provide the necessary access for the ADIS16204's capture buffers: CAPT\_BUF\_1 and CAPT\_BUF\_2. At the completion of a capture event, the contents of theses registers contain the first sample from each buffer. [Figure 25](#page-19-5) provides a diagram that displays the role played by the CAPT\_PNTR register in this process. This register provides a pointer function and automatically increments every time one of the CAP\_BUF\_x registers are read. If efficient data transfer rates are a primary goal, then read all of the contents of one buffer, before moving to the other buffer. Because the CAPT\_PNTR offers both read and write access, individual buffer locations can be accessed by writing the sample number into this register.



#### **Table 37. Capture Register Definitions**



#### **Table 38. CAPT\_BUF\_1 and CAPT\_BUF\_2 Bit Descriptions**



#### **Table 39. CAPT\_PNTR Register Definition**



#### **Table 40. CAPT\_PNTR Bit Descriptions**



## <span id="page-20-0"></span>SECOND-LEVEL ASSEMBLY

The ADIS16204 can be attached to the second-level assembly board using Sn63 (or equivalent) or a Pb-free solder. [Figure 26](#page-20-1) and [Table 41](#page-20-2) provide acceptable solder reflow profiles for each solder type. Note that these profiles may not be the optimum profile for the user's application. In no case should 260°C be exceeded. It is recommended that the user develop a reflow profile based upon the specific application.

In general, keep in mind that the lowest peak temperature and shortest dwell time above the melt temperature of the solder results in less shock and stress to the product. In addition, evaluating the cooling rate and peak temperature can result in a more reliable assembly.



#### <span id="page-20-2"></span>**Table 41. Acceptable Solder Reflow Profiles<sup>1</sup>**

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

<sup>1</sup> Per IPC/JEDEC J-STD-020C.

## <span id="page-21-1"></span><span id="page-21-0"></span>OUTLINE DIMENSIONS



*(CC-16-2) Dimensions shown in millimeters* 

### **ORDERING GUIDE**



 $1 Z =$  RoHS Compliant Part.

## **NOTES**

**OBSOLETE** 

## **NOTES**

**©2007–2009 Analog Devices, Inc. All rights reserved. Trademarks and registered trademarks are the property of their respective owners. D06448-0-12/09(B)** 



**OBSOLETE** 

www.analog.com