Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs. With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas. We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry! ## Contact us Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China # 3-Axis, $\pm 1.5 \ g/\pm 3 \ g/\pm 6 \ g/\pm 12 \ g$ Digital Accelerometer Data Sheet ADXL312 #### **FEATURES** Ultralow power: as low as 57 $\mu A$ in measurement mode and 0.1 $\mu A$ in standby mode at $V_S = 3.3 \ V$ (typical) Power consumption scales automatically with bandwidth User-selectable resolution Fixed 10-bit resolution Full resolution, where resolution increases with g range, up to 13-bit resolution at $\pm 12~g$ (maintaining 2.9 mg/LSB scale factor in all g ranges) Embedded FIFO technology minimizes host processor load Built-in motion detection functions for activity/inactivity monitoring Supply and I/O voltage range: 2.0 V to 3.6 V SPI (3- and 4-wire) and I<sup>2</sup>C digital interfaces Flexible interrupt modes mappable to either interrupt pin Measurement ranges selectable via serial command Bandwidth selectable via serial command Wide temperature range (-40 to +105°C) 10,000 *g* shock survival Pb free/RoHS compliant Small and thin: $5 \text{ mm} \times 5 \text{ mm} \times 1.45 \text{ mm}$ LFCSP package Qualified for automotive applications #### **APPLICATIONS** Car alarm Hill start aid (HSA) Electronic parking brake Data recorder (black box) #### **GENERAL DESCRIPTION** The ADXL312¹ is a small, thin, low power, 3-axis accelerometer with high resolution (13-bit) measurement up to $\pm 12$ g. Digital output data is formatted as 16-bit twos complement and is accessible through either a serial port interface (SPI) (3- or 4-wire) or I²C digital interface. The ADXL312 is well suited for car alarm or black box applications. It measures the static acceleration of gravity in tilt-sensing applications, as well as dynamic acceleration resulting from motion or shock. Its high resolution (2.9 mg/LSB) enables resolution of inclination changes of as little as 0.25°. A built-in FIFO facilitates using oversampling techniques to improve resolution to as little as 0.05° of inclination. Several special sensing functions are provided. Activity and inactivity sensing detects the presence or absence of motion and whether the acceleration on any axis exceeds a user-set level. These functions can be mapped to interrupt output pins. An integrated 32 level FIFO can be used to store data to minimize host processor intervention. Low power modes enable intelligent motion-based power management with threshold sensing and active acceleration measurement at extremely low power dissipation. The ADXL312 is supplied in a small, thin 5 mm $\times$ 5 mm $\times$ 1.45 mm, 32-lead, LFCSP package. #### **FUNCTIONAL BLOCK DIAGRAM** Figure 1. ADXL312 Simplified Block Diagram Trademarks and registered trademarks are the property of their respective owners. <sup>&</sup>lt;sup>1</sup> Protected by U.S. Patent 8,156,264B2. # ADXL312\* PRODUCT PAGE QUICK LINKS Last Content Update: 04/28/2017 ## COMPARABLE PARTS 🖳 View a parametric search of comparable parts. ## **EVALUATION KITS** - · ADXL312Z Breakout Board - Real Time Eval System for Digital Output Sensor ## **DOCUMENTATION** #### **Data Sheet** • ADXL312: 3-Axis, ±1.5 g/±3 g/±6 g/±12 g Digital **Accelerometer Data Sheet** #### **User Guides** - UG-209: ADXL312 Sensor Evaluation System - UG-281: ADXL312 Quick Start User Guide ## DESIGN RESOURCES 🖵 - ADXL312 Material Declaration - PCN-PDN Information - · Quality And Reliability - Symbols and Footprints ### **DISCUSSIONS** View all ADXL312 EngineerZone Discussions. ## SAMPLE AND BUY 🖵 Visit the product page to see pricing options. ## **TECHNICAL SUPPORT** Submit a technical question or find your regional support number. ## DOCUMENT FEEDBACK 🖳 Submit feedback for this data sheet. ## **TABLE OF CONTENTS** | reatures | |--------------------------------------------------------------| | Applications | | General Description1 | | Functional Block Diagram | | Revision History | | Specifications | | Absolute Maximum Ratings5 | | Thermal Resistance5 | | ESD Caution5 | | Pin Configuration and Function Descriptions | | Typical Performance Characteristics | | Theory of Operation | | Power Sequencing | | Power Savings | | Serial Communications | | SPI | | I <sup>2</sup> C | | Interrupts17 | | REVISION HISTORY | | 4/2017—Rev. A to Rev. B | | Changes to Standby Mode Leakage Current Parameter, Table 1 3 | | Updated Outline Dimensions | | Changes to Ordering Guide | | 7/2015—Rev. 0 to Rev. A | | Changes to Features Section | | Changes to Pin 22 Description, Table 4 | | Changes to Serial Communications Section, SPI Section, | | Figure 21, and Figure 22 | | FIFO | |----------------------------------------------| | Self-Test | | Register Map | | Register Definitions | | Applications Information | | Power Supply Decoupling | | Mechanical Considerations for Mounting25 | | Threshold | | Link Mode25 | | Sleep Mode vs. Low Power Mode25 | | Using Self-Test | | Data Formatting of Upper Data Rates27 | | Noise Performance | | Axes of Acceleration Sensitivity | | Solder Profile | | Outline Dimensions | | Ordering Guide | | Automotive Products | | | | | | Added Serial Port I/O Default States Section | #### 12/2010—Revision 0: Initial Version ## **SPECIFICATIONS** $T_{\text{A}} = -40 ^{\circ}\text{C}$ to +105 $^{\circ}\text{C}$ , $V_{\text{S}} = V_{\text{DD I/O}} = 3.3$ V, acceleration = 0 g, unless otherwise noted. Table 1. Specifications<sup>1</sup> | Parameter | Test Conditions/Comments | Min | Тур | Max | Unit | |------------------------------------------------------------------------|-------------------------------------------|-------|----------------|-------|-----------------| | SENSOR INPUT | Each axis | | | | | | Measurement Range | User selectable | | ±1.5, 3, 6, 12 | | g | | Nonlinearity | Percentage of full scale | | ±0.5 | | % | | Inter-Axis Alignment Error | | | ±0.1 | | Degrees | | Cross-Axis Sensitivity <sup>2</sup> | | | ±1 | | % | | OUTPUT RESOLUTION | Each axis | | | | | | All g Ranges | Default resolution | | 10 | | Bits | | ±1.5 <i>g</i> Range | Full resolution enabled | | 10 | | Bits | | ±3 g Range | Full resolution enabled | | 11 | | Bits | | ±6 g Range | Full resolution enabled | | 12 | | Bits | | ±12 <i>g</i> Range | Full resolution enabled | | 13 | | Bits | | SENSITIVITY | Each axis | | | | | | Scale Factor at X <sub>OUT</sub> , Y <sub>OUT</sub> , Z <sub>OUT</sub> | $\pm 1.5 g$ , 10-bit or full resolution | 2.6 | 2.9 | 3.2 | mg/LSB | | Scale Factor at Xout, Yout, Zout | $\pm 3 g$ , 10-bit resolution | 5.2 | 5.8 | 6.4 | mg/LSB | | Scale Factor at Xout, Yout, Zout | ±6 g, 10-bit resolution | 10.4 | 11.6 | 12.8 | mg/LSB | | Scale Factor at X <sub>OUT</sub> , Y <sub>OUT</sub> , Z <sub>OUT</sub> | $\pm$ 12 g, 10-bit resolution | 20.9 | 23.2 | 25.5 | mg/LSB | | Sensitivity at Xout, Yout, Zout | $\pm 1.5 g$ , 10-bit or full resolution | 312 | 345 | 385 | LSB/g | | Sensitivity at Xout, Yout, Zout | ±3 g, 10-bit resolution | 156 | 172 | 192 | LSB/g | | Sensitivity at Xout, Yout, Zout | $\pm 6 g$ , 10-bit resolution | 78 | 86 | 96 | LSB/g | | Sensitivity at Xout, Yout, Zout | $\pm 12 g$ , 10-bit resolution | 39 | 43 | 48 | LSB/g | | Sensitivity Change Due to Temperature | | | ±0.01 | | %/°C | | 0 g BIAS LEVEL | Each axis | | | | | | Initial 0 g Output | T = 25°C, Хоит, Yоит | -150 | | +150 | m <i>g</i> | | Initial 0 g Output | $T = 25$ °C, $Z_{OUT}$ | -250 | | +250 | m <i>g</i> | | 0 g Output over Temperature | -40°C < T < 105°С, Хоит, Yоит, Zоит | -250 | | +250 | m <i>g</i> | | 0 g Offset Tempco | X <sub>OUT</sub> , Y <sub>OUT</sub> | | ±0.8 | | m <i>g/</i> °C | | 0 g Offset Tempco | Z <sub>оит</sub> | | ±1.5 | | m <i>g/</i> °C | | NOISE PERFORMANCE | | | | | | | Noise Density (X-, Y-axes) | | 200 | 340 | 440 | μ <i>g</i> /√Hz | | Noise Density (Z-axis) | | 200 | 470 | 595 | μ <i>g</i> /√Hz | | OUTPUT DATA RATE/BANDWIDTH | User selectable | | | | | | Measurement Rate <sup>3</sup> | | 6.25 | | 3200 | Hz | | SELF-TEST⁴ | Data rate ≥ 100 Hz, $2.0 \le V_S \le 3.6$ | | | | | | Output Change in X-Axis | | 0.20 | | 2.10 | g | | Output Change in Y-Axis | | -2.10 | | -0.20 | g | | Output Change in Z-Axis | | 0.30 | | 3.40 | g | | Parameter | Test Conditions/Comments | Min | Тур | Max | Unit | |-----------------------------------|-----------------------------------------|-----|-----|---------|------| | POWER SUPPLY | | | | | | | Operating Voltage Range (Vs) | | 2.0 | | 3.6 | V | | Interface Voltage Range (VDD 1/0) | | 1.7 | | $V_{S}$ | V | | Supply Current | Data rate > 100 Hz | 100 | 170 | 300 | μΑ | | | Data rate < 10 Hz | 30 | 55 | 110 | μΑ | | Standby Mode Leakage Current | T = 25°C | | 0.1 | 2 | μΑ | | | Over entire operating temperature range | | | 17 | μΑ | | Turn-On (Wake-Up) Time⁵ | | | 1.4 | | ms | | TEMPERATURE | | | | | | | Operating Temperature Range | | -40 | | +105 | °C | <sup>&</sup>lt;sup>1</sup> All minimum and maximum specifications are guaranteed. Typical specifications are not guaranteed. <sup>&</sup>lt;sup>2</sup> Cross-axis sensitivity is defined as coupling between any two axes. <sup>3</sup> Bandwidth is half the output data rate. <sup>4</sup> Self-test change is defined as the output (g) when the SELF\_TEST bit = 1 (in the DATA\_FORMAT register) minus the output (g) when the SELF\_TEST bit = 0 (in the DATA\_FORMAT register). Due to device filtering, the output reaches its final value after $4 \times \tau$ when enabling or disabling self-test, where $\tau = 1/(\text{data rate})$ . 5 Turn-on and wake-up times are determined by the user-defined bandwidth. At a 100 Hz data rate, the turn-on and wake-up times are each approximately 11.1 ms. For other data rates, the turn-on and wake-up times are each approximately $\tau + 1.1$ in milliseconds, where $\tau = 1/(\text{data rate})$ . ## **ABSOLUTE MAXIMUM RATINGS** Table 2. | Parameter | Rating | |------------------------------------------------------|---------------------------------------------------------------------------| | Acceleration | | | Any Axis, Unpowered | 10,000 <i>g</i> | | Any Axis, Powered | 10,000 <i>g</i> | | Vs | −0.3 V to 3.9 V | | V <sub>DD I/O</sub> | -0.3 V to 3.9 V | | All Other Pins | $-0.3 \text{ V to V}_{DDI/O} + 0.3 \text{ V or}$ 3.9 V, whichever is less | | Output Short-Circuit Duration<br>(Any Pin to Ground) | Indefinite | | Temperature Range | | | Powered | -40°C to +125°C | | Storage | −40°C to +125°C | Stresses at or above those listed under Absolute Maximum Ratings may cause permanent damage to the product. This is a stress rating only; functional operation of the product at these or any other conditions above those indicated in the operational section of this specification is not implied. Operation beyond the maximum operating conditions for extended periods may affect product reliability. #### THERMAL RESISTANCE $\theta_{JA}$ is specified for the worst-case conditions, that is, a device soldered in a circuit board for surface-mount packages. **Table 3. Thermal Resistance** | ٠ | Package Type | θ <sub>JA</sub> | <b>Ө</b> лс | Unit | |---|-----------------------|-----------------|-------------|------| | | 32-Lead LFCSP Package | 27.27 | 30 | °C/W | #### **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. ## PIN CONFIGURATION AND FUNCTION DESCRIPTIONS Figure 2. Pin Configuration (Top View) **Table 4. Pin Function Descriptions** | Pin No. | Mnemonic | Description | |----------|---------------------|-----------------------------------------------------------------------------------------------| | 1 | GND | This pin must be connected to ground. | | 2 | Reserved | Reserved. This pin must be connected to V <sub>S</sub> or left open. | | 3 | GND | This pin must be connected to ground. | | 4 | GND | This pin must be connected to ground. | | 5 | Vs | Supply Voltage. | | 6 | CS | Chip Select. | | 7 | Reserved | Reserved. This pin must be left open. | | 8 to19 | NC | No Connect. Do not connect to this pin. | | 20 | INT1 | Interrupt 1 Output. | | 21 | INT2 | Interrupt 2 Output. | | 22 | Reserved | Reserved. This pin must be connected to GND. | | 23 | SDO/ALT ADDRESS | Serial Data Out, Alternate I <sup>2</sup> C Address Select. | | 24 | SDA/SDI/SDIO | Serial Data (I <sup>2</sup> C), Serial Data In (SPI 4-Wire), Serial Data In/Out (SPI 3-Wire). | | 25 | NC | No Connect. Do not connect to this pin. | | 26 | SCL/SCLK | Serial Communications Clock. | | 27 to 30 | NC | No Connect. Do not connect to this pin. | | 31 | V <sub>DD I/O</sub> | Digital Interface Supply Voltage. | | 32 | NC | No Connect. | | | EP | The exposed pad must be soldered to the ground plane. | ## TYPICAL PERFORMANCE CHARACTERISTICS N > 1000, unless otherwise noted. Figure 3. X-Axis Zero-g Bias. 25°C, $V_S = V_{DDI/O} = 3.3 \text{ V}$ Figure 4. Y Axis Zero-g Bias, $25^{\circ}$ C, $V_S = V_{DD VO} = 3.3 \text{ V}$ Figure 5. Z Axis Zero-g Bias, $25^{\circ}$ C, $V_S = V_{DD I/O} = 3.3 \text{ V}$ Figure 6. X-Axis Zero-g Bias Drift, $V_S = V_{DD I/O} = 3.3 \text{ V}$ Figure 7. Y-Axis Zero-g Bias Drift, $V_S = V_{DD I/O} = 3.3 \text{ V}$ Figure 8. Z-Axis Zero-g Bias Drift, $V_S = V_{DD I/O} = 3.3 \text{ V}$ Figure 9. X-Axis Sensitivity, $V_S = V_{DD I/O} = 3.3 \text{ V}, 25^{\circ}\text{C}$ Figure 10. Y-Axis Sensitivity, $V_S = V_{DD I/O} = 3.3 \text{ V}, 25^{\circ}\text{C}$ Figure 11. Z-Axis Sensitivity, $V_S = V_{DD VO} = 3.3 \text{ V}, 25^{\circ}\text{C}$ Figure 12. X-Axis Sensitivity Temperature Coefficient, $V_S = V_{DD \, I/O} = 3.3 \, V$ Figure 13. Y-Axis Sensitivity Temperature Coefficient, $V_S = V_{DD \text{ I/O}} = 3.3 \text{ V}$ Figure 14. Z-Axis Sensitivity Temperature Coefficient, $V_S = V_{DD \text{ I/O}} = 3.3 \text{ V}$ Figure 15. X-Axis Self-Test Delta, $V_S = V_{DD I/O} = 3.3 \text{ V}, 25^{\circ}\text{C}$ Figure 16. Y-Axis Self-Test Delta, $V_S = V_{DDI/O} = 3.3 \text{ V}, 25^{\circ}\text{C}$ Figure 17. Z-Axis Self-Test Delta, $V_S = V_{DDVO} = 3.3 \text{ V}, 25^{\circ}\text{C}$ Figure 18. Standby Mode Current Consumption, $V_S = V_{DD V/O} = 3.3 \text{ V}, 25^{\circ}\text{C}$ Figure 19. Current Consumption, Measurement Mode, Data Rate = 100 Hz, $V_S = V_{DD \ VO} = 3.3 \ V, 25 ^{\circ} C$ Figure 20. Supply Current vs. Supply Voltage, Vs at 25°C ### THEORY OF OPERATION The ADXL312 is a complete 3-axis acceleration measurement system with a selectable measurement range of $\pm 1.5$ g, $\pm 3$ g, $\pm 6$ g, or $\pm 12$ g. It measures both dynamic acceleration resulting from motion or shock and static acceleration, such as gravity, which allows it to be used as a tilt sensor. The sensor is a polysilicon surface-micromachined structure built on top of a silicon wafer. Polysilicon springs suspend the structure over the surface of the wafer and provide a resistance against acceleration forces. Deflection of the structure is measured using differential capacitors that consist of independent fixed plates and plates attached to the moving mass. Acceleration deflects the beam and unbalances the differential capacitor, resulting in a sensor output whose amplitude is proportional to acceleration. Phasesensitive demodulation is used to determine the magnitude and polarity of the acceleration. #### **POWER SEQUENCING** Power can be applied to $V_s$ or $V_{\rm DD\,I/O}$ in any sequence without damaging the ADXL312. All possible power-on modes are summarized in Table 5. The interface voltage level is set with the interface supply voltage, $V_{\rm DD\,I/O}$ , which must be present to ensure that the ADXL312 does not create a conflict on the communication bus. For single-supply operation, $V_{\rm DD\,I/O}$ can be the same as the main supply, $V_s$ . In a dual-supply application, however, $V_{\rm DD\,I/O}$ can differ from $V_s$ to accommodate the desired interface voltage, as long as $V_s$ is greater than or equal to $V_{\rm DD\,I/O}$ . After $V_s$ is applied, the device enters standby mode, where power consumption is minimized and the device waits for $V_{\rm DD\,I/O}$ to be applied and for the command to enter measurement mode to be received. (This command can be initiated by setting the measure bit in the POWER\_CTL register (Address 0x2D).) In addition, any register can be written to or read from to configure the part while the device is in standby mode. It is recommended to configure the device in standby mode and then to enable measurement mode. Clearing the measure bit returns the device to the standby mode. Table 5. Power Sequencing | Condition | Vs | V <sub>DDI/O</sub> | Description | |---------------------------|-----|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Power Off | Off | Off | The device is completely off, but there is a potential for a communication bus conflict. | | Bus Disabled | On | Off | The device is on in standby mode, but communication is unavailable and creates a conflict on the communication bus. The duration of this state must be minimized during power-up to prevent a conflict. | | Bus Enabled | Off | On | No functions are available, but<br>the device will not create a conflict<br>on the communication bus. | | Standby or<br>Measurement | On | On | The device is in standby mode, awaiting a command to enter measurement mode, and all sensor functions are off. After the device is instructed to enter measurement mode, all sensor functions are available. | #### **POWER SAVINGS** #### **Power Modes** The ADXL312 automatically modulates its power consumption in proportion to its output data rate, as outlined in Table 6. If additional power savings is desired, a lower power mode is available. In this mode, the internal sampling rate is reduced, allowing for power savings in the 12.5 Hz to 400 Hz data rate range at the expense of slightly greater noise. To enter low power mode, set the LOW\_POWER bit (Bit 4) in the BW\_RATE register (Address 0x2C). The current consumption in low power mode is shown in Table 7 for cases where there is an advantage to using low power mode. Use of low power mode for a data rate not shown in Table 7 does not provide any advantage over the same data rate in normal power mode. Therefore, it is recommended that only data rates shown in Table 7 be used in low power mode. The current consumption values shown in Table 6 and Table 7 are for a $V_{\rm S}$ of 3.3 V. Table 6. Current Consumption vs. Data Rate $(T_A = 25^{\circ}C, V_S = V_{DD \ VO} = 3.3 \ V)$ | (17, 20 0) 1 9 | - <b>V</b> DD 1/O - 3:3 <b>V</b> ) | | | |----------------|------------------------------------|-----------|----------------------| | Output Data | D 1 : 1:1 (11 ) | 5 . 6 . | | | Rate (Hz) | Bandwidth (Hz) | Rate Code | I <sub>DD</sub> (μA) | | 3200 | 1600 | 1111 | 170 | | 1600 | 800 | 1110 | 115 | | 800 | 400 | 1101 | 170 | | 400 | 200 | 1100 | 170 | | 200 | 100 | 1011 | 170 | | 100 | 50 | 1010 | 170 | | 50 | 25 | 1001 | 115 | | 25 | 12.5 | 1000 | 82 | | 12.5 | 6.25 | 0111 | 65 | | 6.25 | 3.125 | 0110 | 57 | Table 7. Current Draw vs. Data Rate, Low Power Mode $(T_A = 25^{\circ}C, V_S = V_{DD I/O} = 3.3 \text{ V})$ | Output Data<br>Rate (Hz) | Bandwidth (Hz) | Rate Code | I <sub>DD</sub> (μA) | |--------------------------|----------------|-----------|----------------------| | 400 | 200 | 1100 | 115 | | 200 | 100 | 1011 | 82 | | 100 | 50 | 1010 | 65 | | 50 | 25 | 1001 | 57 | | 25 | 12.5 | 1000 | 50 | | 12.5 | 6.25 | 0111 | 43 | #### **Autosleep Mode** Additional power savings can be had by having the ADXL312 automatically switch to sleep mode during periods of inactivity. To enable this feature, set the THRESH\_INACT register (Address 0x25) to an acceleration threshold value. Levels of acceleration below this threshold are regarded as no activity levels. Set TIME\_INACT (Address 0x26) to an appropriate inactivity time period. Then set the AUTO\_SLEEP bit and the link bit in the POWER\_CTL register (Address 0x2D). If the device does not detect a level of acceleration in excess of THRES\_INACT for TIME\_INACT seconds, then the device is transitioned to sleep mode automatically. Current consumption at the sub-8 Hz data rates used in this mode is typically 30 $\mu A$ for a $V_{\rm S}$ of 3.3 V. #### Standby Mode For even lower power operation, standby mode can be used. In standby mode, current consumption is reduced to $0.1\mu A$ (typical). In this mode, no measurements are made. Standby mode is entered by clearing the measure bit (Bit 3) in the POWER\_CTL register (Address 0x2D). Placing the device into standby mode preserves the contents of the FIFO. ## SERIAL COMMUNICATIONS The ADXL312 can communicate via I $^2$ C and SPI digital communications interfaces. In both cases, the ADXL312 operates as a slave. If I $^2$ C is the desired interface for the application, tie the $\overline{\text{CS}}$ pin directly to V $_{\text{DDI/O}}$ as shown in Figure 27. If SPI is the desired interface for the application, drive the $\overline{\text{CS}}$ pin with an external controller, as demonstrated in Figure 21 and Figure 22. Because the I²C interface is enabled any time the $\overline{CS}$ pin is brought up to $V_{DDI/O}$ , there is a potential for bus conflicts to occur when the ADXL312 is implemented into a SPI network. Refer to the Preventing Bus Traffic Errors section for information on how to avoid such conditions. In both SPI and I²C modes of operation, ignore data transmitted from the ADXL312 to the master device during writes to the ADXL312. Note that throughout this section, multifunction pins, such as SDA/SDI/SDIO, are referred to either by the entire pin name or by a single function of the pin, for example, SDA, when only that function is relevant. #### **SERIAL PORT I/O DEFAULT STATES** Ensure that all serial port I/Os are in a defined state and that no pin is allowed to float when not in use. This is applicable to all serial port I/Os, regardless of SPI or I<sup>2</sup>C operation. For I<sup>2</sup>C applications, always tie the $\overline{\text{CS}}$ pin high to V<sub>DD I/O</sub>. Connect the SCL and SDA pins to an external controller, with pull-up resistors implemented according to the *UM10204 I<sup>2</sup>C-Bus Specification and User Manual*, Rev. 03—19 June 2007, available from NXP Semiconductor. The ALT ADDRESS pin must be tied to either V<sub>DD I/O</sub> or ground, thereby selecting the desired I<sup>2</sup>C address for the ADXL312. If SPI is the intended communications interface, drive the $\overline{\text{CS}}$ pin with an external controller, as shown in Figure 21 and Figure 22. When communications with the ADXL312 are suspended ( $\overline{\text{CS}} = V_{\text{DD I/O}}$ ), ensure that the SCLK, SDI/SDIO, and SDO pins are not floating. For either SPI or I<sup>2</sup>C operation, not taking these precautions may result in an inability to communicate with the device or excessive current consumption. #### SPI For the SPI, either 3- or 4-wire configuration is possible, as shown in the connection diagrams in Figure 21 and Figure 22. Clearing the SPI bit in the DATA\_FORMAT register (Address 0x31) selects 4-wire mode, whereas setting the SPI bit selects 3-wire mode. The maximum SPI clock speed is 5 MHz with $100 \, \text{pF}$ maximum loading, and the timing scheme follows clock polarity (CPOL) = 1 and clock phase (CPHA) = 1. If power is applied to the ADXL312 before the clock polarity and phase of the host processor are configured, bring the $\overline{\text{CS}}$ pin high before changing the clock polarity and phase. When using 3-wire SPI, pull the SDO pin up to $V_{\rm DD\,I/O}$ or down to ground via a 10 $k\Omega$ resistor, as shown in Figure 21. CS is the serial port enable line and is controlled by the SPI master. This line must go low at the start of a transmission and high at the end of a transmission, as shown in Figure 24. SCLK is the serial port clock and is supplied by the SPI master. SDI and SDO are the serial data input and output, respectively. Figure 21. 3-Wire SPI Connection Diagram Figure 22. 4-Wire SPI Connection Diagram To read or write multiple bytes in a single transmission, the multiple-byte bit, located after the R/W bit in the first byte transfer (MB in Figure 24 to Figure 26), must be set. After the register addressing and the first byte of data, each subsequent set of clock pulses (eight clock pulses) causes the ADXL312 to point to the next register for a read or write. This shifting continues until the clock pulses cease and $\overline{\text{CS}}$ is deasserted. To perform reads or writes on different nonsequential registers, $\overline{\text{CS}}$ must be deasserted between transmissions, and the new register must be addressed separately. The timing diagram for 3-wire SPI reads or writes is shown in Figure 26. The 4-wire equivalents for SPI writes and reads are shown in Figure 24 and Figure 25, respectively. For correct operation of the device, the logic thresholds and timing parameters in Table 8 and Table 9 must be met at all times. Use of the 3200 Hz and 1600 Hz output data rates is only recommended with SPI communication rates greater than or equal to 2 MHz. The 800 Hz output data rate is recommended only for communication speeds greater than or equal to 400 kHz, and the remaining data rates scale proportionally. For example, the minimum recommended communication speed for a 200 Hz output data rate is 100 kHz. Operation at an output data rate below the recommended minimum may result in undesirable effects on the acceleration data, including missing samples or additional noise. ### **Preventing Bus Traffic Errors** The ADXL312 $\overline{\text{CS}}$ pin initiates SPI transactions and enables I<sup>2</sup>C mode. When the ADXL312 is used on a SPI bus with multiple devices, its $\overline{\text{CS}}$ pin is held high while the master communicates with the other devices. There may be conditions where a SPI command transmitted to another device looks like a valid I<sup>2</sup>C command. In this case, the ADXL312 interprets this as an attempt to communicate in I<sup>2</sup>C mode and may interfere with other bus traffic. Unless bus traffic can be adequately controlled to ensure such a condition never occurs, it is recommended to add a logic gate in front of the SDI pin, as shown in Figure 23. This OR gate holds the SDA line high when $\overline{CS}$ is high to prevent bus traffic at the ADXL312 from appearing as an I<sup>2</sup>C start command. Figure 23. Recommended SPI Connection Diagram when Using Multiple SPI Devices on a Single Bus Table 8. SPI Digital Input/Output | | | | Limit <sup>1</sup> | | | |---------------------------------------------|--------------------------------------------------|-------------------------|-------------------------|------|--| | Parameter | <b>Test Conditions</b> | Min | Max | Unit | | | Digital Input | | | | | | | Low Level Input Voltage (V <sub>IL</sub> ) | | | $0.3 \times V_{DD I/O}$ | V | | | High Level Input Voltage (V <sub>IH</sub> ) | | $0.7 \times V_{DD I/O}$ | | V | | | Low Level Input Current (I <sub>IL</sub> ) | $V_{IN} = V_{DDI/O}$ | | 0.1 | μΑ | | | High Level Input Current (I <sub>IH</sub> ) | $V_{IN} = 0 V$ | -0.1 | | μΑ | | | Digital Output | | | | | | | Low Level Output Voltage (Vol) | $I_{OL} = 10 \text{ mA}$ | | $0.2 \times V_{DD I/O}$ | V | | | High Level Output Voltage (Vон) | $I_{OH} = -4 \text{ mA}$ | $0.8 \times V_{DD I/O}$ | | V | | | Low Level Output Current (IoL) | $V_{OL} = V_{OL, max}$ | 10 | | mA | | | High Level Output Current (Іон) | $V_{OH} = V_{OH, min}$ | | -4 | mA | | | Pin Capacitance | $f_{IN} = 1 \text{ MHz}, V_{IN} = 2.5 \text{ V}$ | | 8 | рF | | <sup>&</sup>lt;sup>1</sup> Limits based on characterization results, not production tested. Table 9. SPI Timing $(T_A = 25^{\circ}C, V_S = V_{DD I/O} = 3.3 V)^{1}$ | | Limit | 2, 3 | | | |---------------------------|-----------------------|------|------|--------------------------------------------------------------------------------| | Parameter | Min | Max | Unit | Description | | f <sub>SCLK</sub> | | 5 | MHz | SPI clock frequency. | | t <sub>SCLK</sub> | 200 | | ns | 1/(SPI clock frequency) mark-space ratio for the SCLK input is 40/60 to 60/40. | | t <sub>DELAY</sub> | 5 | | ns | CS falling edge to SCLK falling edge . | | <b>t</b> <sub>QUIET</sub> | 5 | | ns | SCLK rising edge to $\overline{\text{CS}}$ rising edge. | | t <sub>DIS</sub> | | 10 | ns | CS rising edge to SDO disabled. | | t <sub>CS,DIS</sub> | 150 | | ns | CS deassertion between SPI communications. | | $t_{\text{S}}$ | $0.3 \times t_{SCLK}$ | | ns | SCLK low pulse width (space). | | $t_{M}$ | $0.3 \times t_{SCLK}$ | | ns | SCLK high pulse width (mark). | | t <sub>SETUP</sub> | 5 | | ns | SDI valid before SCLK rising edge. | | t <sub>HOLD</sub> | 5 | | ns | SDI valid after SCLK rising edge. | | $t_{\text{SDO}}$ | | 40 | ns | SCLK falling edge to SDO/SDIO output transition. | | $t_R^4$ | | 20 | ns | SDO/SDIO output high to output low transition. | | $t_F^4$ | | 20 | ns | SDO/SDIO output low to output high transition. | $<sup>^{1}</sup>$ The $\overline{\text{CS}}$ , SCLK, SDI, and SDO pins are not internally pulled up or down; they must be driven for proper operation. $<sup>^2</sup>$ Limits based on characterization results, characterized with $f_{SCLK} = 5$ MHz and bus load capacitance of 100 pF; not production tested. <sup>&</sup>lt;sup>3</sup> The timing values are measured corresponding to the input thresholds (V<sub>IL</sub> and V<sub>IH</sub>) given in Table 8. <sup>&</sup>lt;sup>4</sup> Output rise and fall times measured with capacitive load of 150 pF. Figure 26. SPI 3-Wire Read/Write #### I<sup>2</sup>C With $\overline{\text{CS}}$ tied high to V<sub>DDI/O</sub>, the ADXL312 is in I<sup>2</sup>C mode, requiring a simple 2-wire connection as shown in Figure 27. The ADXL312 conforms to the *UM10204 I<sup>2</sup>C-Bus Specification* and User Manual, Rev. 03—19 June 2007, available from NXP Semiconductor. It supports standard (100 kHz) and fast (400 kHz) data transfer modes if the bus parameters given in Table 10 and Table 11 are met. Single- or multiple-byte reads/writes are supported, as shown in Figure 28. With the ALT ADDRESS pin high, the 7-bit I<sup>2</sup>C address for the device is 0x1D, followed by the R/W bit. This translates to 0x3A for a write and 0x3B for a read. An alternate I<sup>2</sup>C address of 0x53 (followed by the R/W bit) can be chosen by grounding the ALT ADDRESS pin (Pin 7). This translates to 0xA6 for a write and 0xA7 for a read. Figure 27. I<sup>2</sup>C Connection Diagram (Address 0x53) If other devices are connected to the same I<sup>2</sup>C bus, the nominal operating voltage level of these other devices cannot exceed V<sub>DDI/O</sub> by more than 0.3 V. External pull-up resistors, R<sub>P</sub>, are necessary for proper I<sup>2</sup>C operation. Refer to the *UM10204 I<sup>2</sup>C-Bus Specification and User Manual*, Rev. 03—19 June 2007, when selecting pull-up resistor values to ensure proper operation. Table 10. I<sup>2</sup>C Digital Input/Output | | | Lin | Limit <sup>1</sup> | | | |---------------------------------------------|--------------------------------------------------|-------------------------|-------------------------|------|--| | Parameter | Test Conditions | Min | Max | Unit | | | Digital Input | | | | | | | Low Level Input Voltage (V <sub>IL</sub> ) | | | $0.3 \times V_{DD I/O}$ | V | | | High Level Input Voltage (V <sub>IH</sub> ) | | $0.7 \times V_{DD I/O}$ | | V | | | Low Level Input Current (I⊥) | $V_{IN} = V_{DD\ I/O}$ | | 0.1 | μΑ | | | High Level Input Current (I <sub>H</sub> ) | $V_{IN} = 0 V$ | -0.1 | | μΑ | | | Digital Output | | | | | | | Low Level Output Voltage (Vol) | $V_{DD I/O} < 2 V$ , $I_{OL} = 3 \text{ mA}$ | | $0.2 \times V_{DD I/O}$ | V | | | | $V_{DD VO} \ge 2 V$ , $I_{OL} = 3 \text{ mA}$ | | 400 | mV | | | Low Level Output Current (IoL) | $V_{OL} = V_{OL, max}$ | 3 | | mA | | | Pin Capacitance | $f_{IN} = 1 \text{ MHz}, V_{IN} = 2.5 \text{ V}$ | | 8 | рF | | <sup>&</sup>lt;sup>1</sup> Limits based on characterization results; not production tested. #### NOTES 1. THIS START IS EITHER A RESTART OR A STOP FOLLOWED BY A START. 2. THE SHADED AREAS REPRESENT WHEN THE DEVICE IS LISTENING. Figure 28. I<sup>2</sup>C Device Addressing **Table 11. I**<sup>2</sup>**C Timing** ( $T_A = 25^{\circ}\text{C}$ , $V_S = V_{DD \text{ I/O}} = 3.3 \text{ V}$ ) | | | Limit <sup>1, 2</sup> | | | |-----------------------|------------|-----------------------|------|-------------------------------------------------------------------------------------| | Parameter | Min | Max | Unit | Description | | f <sub>SCL</sub> | | 400 | kHz | SCL clock frequency | | t <sub>1</sub> | 2.5 | | μs | SCL cycle time | | t <sub>2</sub> | 0.6 | | μs | t <sub>HIGH</sub> , SCL high time | | t <sub>3</sub> | 1.3 | | μs | t <sub>LOW</sub> , SCL low time | | t <sub>4</sub> | 0.6 | | μs | t <sub>HD, STA</sub> , start/repeated start condition hold time | | <b>t</b> <sub>5</sub> | 100 | | ns | t <sub>SU, DAT</sub> , data setup time | | $t_6^{3, 4, 5, 6}$ | 0 | 0.9 | μs | t <sub>HD, DAT</sub> , data hold time | | t <sub>7</sub> | 0.6 | | μs | t <sub>SU, STA</sub> , setup time for repeated start | | t <sub>8</sub> | 0.6 | | μs | t <sub>SU, STO</sub> , stop condition setup time | | t <sub>9</sub> | 1.3 | | μs | t <sub>BUF</sub> , bus-free time between a stop condition and a start condition | | t <sub>10</sub> | | 300 | ns | t <sub>R</sub> , rise time of both SCL and SDA when receiving | | | 0 | | ns | t <sub>R</sub> , rise time of both SCL and SDA when receiving or transmitting | | t <sub>11</sub> | | 250 | ns | $t_{\text{F}}$ , fall time of SDA when receiving | | | | 300 | ns | $t_{\text{F}}$ , fall time of both SCL and SDA when transmitting | | | 20 + 0.1 C | .b <sup>7</sup> | ns | $t_{\mbox{\tiny F}}$ , fall time of both SCL and SDA when transmitting or receiving | | C <sub>b</sub> | | 400 | рF | Capacitive load for each bus line | $<sup>^{1}</sup>$ Limits based on characterization results, with $f_{SCL} = 400 \text{ kHz}$ and a 3 mA sink current; not production tested. <sup>&</sup>lt;sup>7</sup> C<sub>b</sub> is the total capacitance of one bus line in picofarads. Figure 29. I<sup>2</sup>C Timing Diagram $<sup>^2</sup>$ All values referred to the $V_{IH}$ and the $V_{IL}$ levels given in Table 10. $<sup>^3</sup>$ t<sub>6</sub> is the data hold time that is measured from the falling edge of SCL. It applies to data in transmission and acknowledge. <sup>&</sup>lt;sup>4</sup> A transmitting device must internally provide an output hold time of at least 300 ns for the SDA signal (with respect to V<sub>IH(min)</sub> of the SCL signal) to bridge the undefined region of the falling edge of SCL. $<sup>^5</sup>$ The maximum $t_6$ value must be met only if the device does not stretch the low period $(t_3)$ of the SCL signal. <sup>&</sup>lt;sup>6</sup> The maximum value for $t_6$ is a function of the clock low time ( $t_3$ ), the clock rise time ( $t_{10}$ ), and the minimum data setup time ( $t_{5(min)}$ ). This value is calculated as $t_{6(max)} = t_3 - t_{10} - t_{5(min)}$ . #### **INTERRUPTS** The ADXL312 provides two output pins for driving interrupts: INT1 and INT2. Both interrupt pins are push-pull, low impedance pins with output specifications shown in Table 12. The default configuration of the interrupt pins is active high. This can be changed to active low by setting the INT\_INVERT bit in the DATA\_FORMAT (Address 0x31) register. All functions can be used simultaneously, with the only limiting feature being that some functions may need to share interrupt pins. Interrupts are enabled by setting the appropriate bit in the INT\_ENABLE register (Address 0x2E) and are mapped to either the INT1 or INT2 pin based on the contents of the INT\_MAP register (Address 0x2F). When initially configuring the interrupt pins, it is recommended that the functions and interrupt mapping be done before enabling the interrupts. When changing the configuration of an interrupt, it is recommended that the interrupt be disabled first, by clearing the bit corresponding to that function in the INT\_ENABLE register, and then the function be reconfigured before enabling the interrupt again. Configuration of the functions while the interrupts are disabled helps to prevent the accidental generation of an interrupt before desired. The interrupt functions are latched and cleared by either reading the data registers (Address 0x32 to Address 0x37) until the interrupt condition is no longer valid for the data-related interrupts or by reading the INT\_SOURCE register (Address 0x30) for the remaining interrupts. This section describes the interrupts that can be set in the INT\_ENABLE register and monitored in the INT\_SOURCE register. #### Table 12. Interrupt Pin Digital Output #### DATA READY The DATA\_READY bit is set when new data is available and is cleared when no new data is available. #### Activity The activity bit is set when acceleration greater than the value stored in the THRESH\_ACT register (Address 0x24) is experienced. #### Inactivity The inactivity bit is set when acceleration of less than the value stored in the THRESH\_INACT register (Address 0x25) is experienced for more time than is specified in the TIME\_INACT register (Address 0x26). The maximum value for TIME\_INACT is 255 sec. #### Watermark The watermark bit is set when the number of samples in FIFO equals the value stored in the samples bits (Register FIFO\_CTL, Address 0x38). The watermark bit is cleared automatically when FIFO is read, and the content returns to a value below the value stored in the samples bits. #### Overrun The overrun bit is set when new data replaces unread data. The precise operation of the overrun function depends on the FIFO mode. In bypass mode, the overrun bit is set when new data replaces unread data in the DATAX, DATAY, and DATAZ registers (Address 0x32 to Address 0x37). In all other modes, the overrun bit is set when FIFO is filled. The overrun bit is automatically cleared when the contents of FIFO are read. | | | | Limit <sup>1</sup> | | |------------------------------------------|--------------------------------------------------|-------------------------|------------------------|------| | Parameter | <b>Test Conditions</b> | Min | Max | Unit | | Digital Output | | | | | | Low Level Output Voltage (Vol) | $I_{OL} = 300 \mu A$ | | $0.2 \times V_{DDI/O}$ | V | | High Level Output Voltage (Vон) | $I_{OH} = -150 \mu A$ | $0.8 \times V_{DD I/O}$ | | V | | Low Level Output Current (IoL) | $V_{OL} = V_{OL, max}$ | 300 | | μΑ | | High Level Output Current (Іон) | $V_{OH} = V_{OH, min}$ | | -150 | μΑ | | Pin Capacitance | $f_{IN} = 1 \text{ MHz}, V_{IN} = 2.5 \text{ V}$ | | 8 | pF | | Rise/Fall Time | | | | | | Rise Time (t <sub>R</sub> ) <sup>2</sup> | $C_{LOAD} = 150 pF$ | | 210 | ns | | Fall Time (t <sub>F</sub> ) <sup>3</sup> | $C_{LOAD} = 150 pF$ | | 150 | ns | <sup>&</sup>lt;sup>1</sup> Limits based on characterization results, not production tested. $<sup>^2</sup>$ Rise time is measured as the transition time from $V_{\text{OL},\,\text{max}}$ to $V_{\text{OH},\,\text{min}}$ of the interrupt pin. $<sup>^3</sup>$ Fall time is measured as the transition time from $V_{OH,\,min}$ to $V_{OL,\,max}$ of the interrupt pin. #### **FIFO** The ADXL312 contains technology for an embedded memory management system with 32-level FIFO that can be used to minimize host processor burden. This buffer has four modes: bypass, FIFO, stream, and trigger (see Table 21). Each mode is selected by the settings of the FIFO\_MODE bits in the FIFO\_CTL register (Address 0x38). #### **Bypass Mode** In bypass mode, FIFO is not operational and, therefore, remains empty. #### FIFO Mode In FIFO mode, data from measurements of the x-, y-, and z-axes are stored in FIFO. When the number of samples in FIFO equals the level specified in the samples bits of the FIFO\_CTL register (Address 0x38), the watermark interrupt is set. FIFO continues accumulating samples until it is full (32 samples from measurements of the x-, y-, and z-axes) and then stops collecting data. After FIFO stops collecting data, the device continues to operate; therefore, features such as activity detection can be used after FIFO is full. The watermark interrupt continues to occur until the number of samples in FIFO is less than the value stored in the samples bits of the FIFO\_CTL register. #### Stream Mode In stream mode, data from measurements of the x-, y-, and z-axes are stored in FIFO. When the number of samples in FIFO equals the level specified in the samples bits of the FIFO\_CTL register (Address 0x38), the watermark interrupt is set. FIFO continues accumulating samples and holds the latest 32 samples from measurements of the x-, y-, and z-axes, discarding older data as new data arrives. The watermark interrupt continues occurring until the number of samples in FIFO is less than the value stored in the samples bits of the FIFO\_CTL register. #### Trigger Mode In trigger mode, FIFO accumulates samples, holding the latest 32 samples from measurements of the x-, y-, and z-axes. After a trigger event occurs and an interrupt is sent to the INT1 or INT2 pin (determined by the trigger bit in the FIFO\_CTL register), FIFO keeps the last n samples (where n is the value specified by the samples bits in the FIFO\_CTL register) and then operates in FIFO mode, collecting new samples only when FIFO is not full. A delay of at least 5 $\mu$ s must be present between the trigger event occurring and the start of reading data from the FIFO to allow the FIFO to discard and retain the necessary samples. Additional trigger events cannot be recognized until the trigger mode is reset. To reset the trigger mode, set the device to bypass mode and then set the device back to trigger mode. Note that the FIFO data must be read first because placing the device into bypass mode clears FIFO. #### **Retrieving Data from FIFO** The FIFO data is read through the DATAX, DATAY, and DATAZ registers (Address 0x32 to Address 0x37). When the FIFO is in FIFO, stream, or trigger mode, reads to the DATAX, DATAY, and DATAZ registers read data stored in the FIFO. Each time data is read from the FIFO, the oldest x-, y-, and z-axes data is placed into the DATAX, DATAY and DATAZ registers. If a single-byte read operation is performed, the remaining bytes of data for the current FIFO sample are lost. Therefore, all axes of interest must be read in a burst (or multiple-byte) read operation. To ensure that the FIFO has completely popped (that is, that new data has completely moved into the DATAX, DATAY, and DATAZ registers), there must be at least 5 $\mu$ s between the end of reading the data registers and the start of a new read of the FIFO or a read of the FIFO\_STATUS register (Address 0x39). The end of reading a data register is signified by the transition from Register 0x37 to Register 0x38 or by the $\overline{\text{CS}}$ pin going high. For SPI operation at 1.6 MHz or less, the register addressing portion of the transmission is a sufficient delay to ensure that the FIFO has completely popped. For SPI operation greater than 1.6 MHz, it is necessary to deassert the $\overline{\text{CS}}$ pin to ensure a total delay of 5 $\mu\text{s}$ ; otherwise, the delay will not be sufficient. The total delay necessary for 5 MHz operation is at most 3.4 $\mu\text{s}$ . This is not a concern when using I²C mode because the communication rate is low enough to ensure a sufficient delay between FIFO reads. #### **SELF-TEST** The ADXL312 incorporates a self-test feature that effectively tests its mechanical and electronic systems simultaneously. When the self-test function is enabled (via the SELF\_TEST bit in the DATA\_FORMAT register, Address 0x31), an electrostatic force is exerted on the mechanical sensor. This electrostatic force moves the mechanical sensing element in the same manner as acceleration, and it is additive to the acceleration experienced by the device. This added electrostatic force results in an output change in the x-, y-, and z-axes. Because the electrostatic force is proportional to $V_S^2$ , the output change varies with $V_S$ . This effect is shown in Figure 30. The scale factors shown in Table 13 can be used to adjust the expected self-test output limits for different supply voltages, Vs. The self-test feature of the ADXL312 also exhibits a bimodal behavior. However, the limits shown in Table 1 and Table 14 to Table 17 are valid for both potential self-test values due to bimodality. Use of the self-test feature at data rates less than 100 Hz or at 1600 Hz may yield values outside these limits. Therefore, the part must be in normal power operation (LOW\_POWER bit = 0 in BW\_RATE register, Address 0x2C) and be placed into a data rate of 100 Hz through 800 Hz or 3200 Hz for the self-test function to operate correctly. Figure 30. Self-Test Output Change Limits vs. Supply Voltage Table 13. Self-Test Output Scale Factors for Different Supply Voltages, Vs | Supply Voltage, Vs | X-, Y-Axes | Z-Axis | |--------------------|------------|--------| | 2.00 V | 0.64 | 0.8 | | 2.50 V | 1.00 | 1.00 | | 3.00 V | 1.77 | 1.47 | | 3.30 V | 2.11 | 1.69 | Table 14. Self-Test Output in LSB for $\pm 1.5$ g, 10-Bit or Full Resolution ( $T_A = 25$ °C, $V_S = V_{DD I/O} = 2.5$ V) | Axis | Min | Max | Unit | |------|------|------|------| | Х | 65 | 725 | LSB | | Υ | -725 | -65 | LSB | | Z | 100 | 1175 | LSB | Table 15. Self-Test Output in LSB for $\pm 3$ g, 10-Bit Resolution ( $T_A = 25^{\circ}\text{C}$ , $V_S = V_{\rm DD\,I/O} = 2.5 \text{ V}$ ) | Axis | Min | Max | Unit | |------|------|-----|------| | Χ | 32 | 362 | LSB | | Υ | -362 | -32 | LSB | | Z | 50 | 588 | LSB | Table 16. Self-Test Output in LSB for $\pm 6$ g, 10-Bit Resolution ( $T_A = 25^{\circ}\text{C}$ , $V_S = V_{\text{DD I/O}} = 2.5 \text{ V}$ ) | Axis | Min | Max | Unit | |------|------|-----|------| | Χ | 16 | 181 | LSB | | Υ | -181 | -16 | LSB | | Z | 25 | 294 | LSB | Table 17. Self-Test Output in LSB for $\pm 12 g$ , 10-Bit Resolution ( $T_A = 25^{\circ}C$ , $V_S = V_{DDI/O} = 2.5 V$ ) | | ` | , | | | |------|---|-----|-----|------| | Axis | | Min | Max | Unit | | | X | 8 | 90 | LSB | | | Υ | -90 | -8 | LSB | | | Z | 12 | 147 | LSB | ## **REGISTER MAP** Table 18. Register Map | Address | | | | | | |--------------|---------|---------------|------|-------------|------------------------------------------------------------| | Hex | Dec | Name | Туре | Reset Value | Description | | 0x00 | 0 | DEVID | R | 11100101 | Device ID. | | 0x01 to 0x1D | 1 to 29 | Reserved | | | Reserved. Do not access. | | 0x1E | 30 | OFSX | R/W | 00000000 | X-axis offset. | | 0x1F | 31 | OFSY | R/W | 00000000 | Y-axis offset. | | 0x20 | 32 | OFSZ | R/W | 00000000 | Z-axis offset. | | 0x21 | 33 | Reserved | | | Reserved. Do not access. | | 0x22 | 34 | Reserved | | | Reserved. Do not access. | | 0x23 | 35 | Reserved | | | Reserved. Do not access. | | 0x24 | 36 | THRESH_ACT | R/W | 00000000 | Activity threshold. | | 0x25 | 37 | THRESH_INACT | R/W | 00000000 | Inactivity threshold. | | 0x26 | 38 | TIME_INACT | R/W | 00000000 | Inactivity time. | | 0x27 | 39 | ACT_INACT_CTL | R/W | 00000000 | Axis enable control for activity and inactivity detection. | | 0x28 | 40 | Reserved | | | Reserved. Do not access. | | 0x29 | 41 | Reserved | | | Reserved. Do not access. | | 0x2A | 42 | Reserved | | | Reserved. Do not access. | | 0x2B | 43 | Reserved | | | Reserved. Do not access. | | 0x2C | 44 | BW_RATE | R/W | 00001010 | Data rate and power mode control. | | 0x2D | 45 | POWER_CTL | R/W | 00000000 | Power-saving features control. | | 0x2E | 46 | INT_ENABLE | R/W | 00000000 | Interrupt enable control. | | 0x2F | 47 | INT_MAP | R/W | 00000000 | Interrupt mapping control. | | 0x30 | 48 | INT_SOURCE | R | 00000010 | Source of interrupts. | | 0x31 | 49 | DATA_FORMAT | R/W | 00000000 | Data format control. | | 0x32 | 50 | DATAX0 | R | 00000000 | X-Axis Data 0. | | 0x33 | 51 | DATAX1 | R | 00000000 | X-Axis Data 1. | | 0x34 | 52 | DATAY0 | R | 00000000 | Y-Axis Data 0. | | 0x35 | 53 | DATAY1 | R | 00000000 | Y-Axis Data 1. | | 0x36 | 54 | DATAZ0 | R | 00000000 | Z-Axis Data 0. | | 0x37 | 55 | DATAZ1 | R | 00000000 | Z-Axis Data 1. | | 0x38 | 56 | FIFO_CTL | R/W | 00000000 | FIFO control. | | 0x39 | 57 | FIFO_STATUS | R | 00000000 | FIFO status. | #### **REGISTER DEFINITIONS** #### Register 0x00—DEVID (Read Only) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|----|----| | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | The DEVID register holds a fixed device ID code of 0xE5. # Register 0x1E, Register 0x1F, Register 0x20—OFSX, OFSY, OFSZ (Read/Write) The OFSX, OFSY, and OFSZ registers are each eight bits and offer user-set offset adjustments in twos complement format with a scale factor of 11.6 mg/LSB (that is, 0x7F = +1.5 g). The value stored in the offset registers is automatically added to the acceleration data, and the resulting value is stored in the output data registers. #### Register 0x24—THRESH\_ACT (Read/Write) The THRESH\_ACT register is eight bits and holds the threshold value for detecting activity. The data format is unsigned; therefore, the magnitude of the activity event is compared with the value in the THRESH\_ACT register. The scale factor is 46.4 mg/LSB. A value of 0 may result in undesirable behavior if the activity interrupt is enabled. #### Register 0x25—THRESH INACT (Read/Write) The THRESH\_INACT register is eight bits and holds the threshold value for detecting inactivity. The data format is unsigned; therefore, the magnitude of the inactivity event is compared with the value in the THRESH\_INACT register. The scale factor is 46.4 mg/LSB. A value of 0 may result in undesirable behavior if the inactivity interrupt is enabled. #### Register 0x26—TIME\_INACT (Read/Write) The TIME\_INACT register is eight bits and contains an unsigned time value representing the amount of time that acceleration must be less than the value in the THRESH\_INACT register for inactivity to be declared. The scale factor is 1 sec/LSB. Unlike the other interrupt functions, which use unfiltered data (see the Threshold section), the inactivity function uses filtered output data. At least one output sample must be generated for the inactivity interrupt to be triggered. This results in the function appearing unresponsive if the TIME\_INACT register is set to a value less than the time constant of the output data rate. A value of 0 results in an interrupt when the output data is less than the value in the THRESH\_INACT register. ### Register 0x27—ACT\_INACT\_CTL (Read/Write) | D7 | D6 | D5 | D4 | |-------------|----------------|----------------|----------------| | ACT ac/dc | ACT_X enable | ACT_Y enable | ACT_Z enable | | D3 | D2 | D1 | D0 | | INACT ac/dc | INACT_X enable | INACT_Y enable | INACT_Z enable | ### ACT AC/DC and INACT AC/DC Bits A setting of 0 selects dc-coupled operation, and a setting of 1 enables ac-coupled operation. In dc-coupled operation, the current acceleration magnitude is compared directly with THRESH\_ACT and THRESH\_INACT to determine whether activity or inactivity is detected. In ac-coupled operation for activity detection, the acceleration value at the start of activity detection is taken as a reference value. New samples of acceleration are then compared to this reference value and, if the magnitude of the difference exceeds the THRESH\_ACT value, the device triggers an activity interrupt. Similarly, in ac-coupled operation for inactivity detection, a reference value is used for comparison and is updated whenever the device exceeds the inactivity threshold. After the reference value is selected, the device compares the magnitude of the difference between the reference value and the current acceleration with THRESH\_INACT. If the difference is less than the value in THRESH\_INACT for the time in TIME\_INACT, the device is considered inactive and the inactivity interrupt is triggered. #### ACT\_x Enable Bits and INACT\_x Enable Bits A setting of 1 enables x-, y-, or z-axis participation in detecting activity or inactivity. A setting of 0 excludes the selected axis from participation. If all axes are excluded, the function is disabled. For activity detection, all participating axes are logically ORed, causing the activity function to trigger when any of the participating axes exceeds the threshold. For inactivity detection, all participating axes are logically ANDed, causing the inactivity function to trigger only if all participating axes are below the threshold for the specified period of time. #### Register 0x2C—BW\_RATE (Read/Write) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|-----------|----|----|-----|----| | 0 | 0 | 0 | LOW_POWER | | Ra | ite | | #### LOW POWER Bit A setting of 0 in the LOW\_POWER bit selects normal operation, and a setting of 1 selects reduced power operation, which has somewhat higher noise (see the Power Modes section for details). #### **Rate Bits** These bits select the device bandwidth and output data rate (see Table 6 and Table 7 for details). The default value is 0x0A, which translates to a 100 Hz output data rate. An output data rate must be selected that is appropriate for the communication protocol and frequency selected. Selecting too high of an output data rate with a low communication speed results in samples being discarded. ### Register 0x2D—POWER\_CTL (Read/Write) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|------|------------|---------|-------|------|-----| | 0 | 0 | Link | AUTO_SLEEP | Measure | Sleep | Wake | eup | #### Link Bit A setting of 1 in the link bit with both the activity and inactivity functions enabled delays the start of the activity function until inactivity is detected. After activity is detected, inactivity detection begins, preventing the detection of activity. This bit serially links the activity and inactivity functions. When this bit is set to 0, the inactivity and activity functions are concurrent. Additional information can be found in the Link Mode section. When clearing the link bit, it is recommended that the part be placed into standby mode and then set back to measurement mode with a subsequent write. This is done to ensure that the device is properly biased if sleep mode is manually disabled; otherwise, the first few samples of data after the link bit is cleared may have additional noise, especially if the device was asleep when the bit was cleared. #### AUTO\_SLEEP Bit If the link bit is set, a setting of 1 in the AUTO\_SLEEP bit sets the ADXL312 to switch to sleep mode when inactivity is detected (that is, when acceleration has been below the THRESH\_INACT value for at least the time indicated by TIME\_INACT). A setting of 0 disables automatic switching to sleep mode. See the description of the sleep bit in this section for more information. When clearing the AUTO\_SLEEP bit, it is recommended that the part be placed into standby mode and then set back to measurement mode with a subsequent write. This is done to ensure that the device is properly biased if sleep mode is manually disabled; otherwise, the first few samples of data after the AUTO\_SLEEP bit is cleared may have additional noise, especially if the device was asleep when the bit was cleared. #### **Measure Bit** A setting of 0 in the measure bit places the part into standby mode, and a setting of 1 places the part into measurement mode. The ADXL312 powers up in standby mode with minimum power consumption. #### Sleep Bit A setting of 0 in the sleep bit puts the part into the normal mode of operation, and a setting of 1 places the part into sleep mode. Sleep mode suppresses DATA\_READY (see Register 0x2E, Register 0x2F, and Register 0x30), stops transmission of data to FIFO, and switches the sampling rate to one specified by the wake-up bits. In sleep mode, only the activity function can be used. When clearing the sleep bit, it is recommended that the part be placed into standby mode and then set back to measurement mode with a subsequent write. This is done to ensure that the device is properly biased if sleep mode is manually disabled; otherwise, the first few samples of data after the sleep bit is cleared may have additional noise, especially if the device was asleep when the bit was cleared. #### Wake-Up Bits These bits control the frequency of readings in sleep mode as described in Table 19. Table 19. Frequency of Readings in Sleep Mode | Setting | | | |---------|---|----------------| | D1 D0 | | Frequency (Hz) | | 0 | 0 | 8 | | 0 | 1 | 4 | | 1 | 0 | 2 | | 1 | 1 | 1 | #### Register 0x2E—INT\_ENABLE (Read/Write) | D7 | D6 | D5 | D4 | |------------|-----|-----------|----------| | DATA_READY | N/A | N/A | Activity | | D3 | D2 | D1 | D0 | | Inactivity | N/A | Watermark | Overrun | Setting bits in this register to a value of 1 enables their respective functions to generate interrupts, whereas a value of 0 prevents the functions from generating interrupts. The DATA\_READY, watermark, and overrun bits enable only the interrupt output; the functions are always enabled. It is recommended that interrupts be configured before enabling their outputs. Register 0x2F—INT\_MAP (Read/Write) | D7 | D6 | D5 | D4 | |------------|-----|-----------|----------| | DATA_READY | N/A | N/A | Activity | | D3 | D2 | D1 | D0 | | Inactivity | N/A | Watermark | Overrun | Any bits set to 0 in this register send their respective interrupts to the INT1 pin, whereas bits set to 1 send their respective interrupts to the INT2 pin. All selected interrupts for a given pin are ORed. Register 0x30—INT\_SOURCE (Read Only) | D7 | D6 | D5 | D4 | |------------|-----|-----------|----------| | DATA_READY | N/A | N/A | Activity | | D3 | D2 | D1 | D0 | | Inactivity | N/A | Watermark | Overrun | Bits set to 1 in this register indicate that their respective functions have triggered an event, whereas a value of 0 indicates that the corresponding event has not occurred. The DATA\_READY, watermark, and overrun bits are always set if the corresponding events occur, regardless of the INT\_ENABLE register settings, and are cleared by reading data from the DATAX, DATAY, and DATAZ registers. The DATA\_READY and watermark bits may require multiple reads, as indicated in the FIFO mode descriptions in the FIFO section. Other bits, and the corresponding interrupts, are cleared by reading the INT\_SOURCE register. #### Register 0x31—DATA\_FORMAT (Read/Write) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----------|-----|------------|----|----------|---------|-----|-----| | SELF_TEST | SPI | INT_INVERT | 0 | FULL_RES | Justify | Rar | nge | The DATA\_FORMAT register controls the presentation of data to Register 0x32 through Register 0x37. All data, except that for the $\pm 12$ g range, must be clipped to avoid rollover. ### SELF\_TEST Bit A setting of 1 in the SELF\_TEST bit applies a self-test force to the sensor, causing a shift in the output data. A value of 0 disables the self-test force. #### **SPI Bit** A value of 1 in the SPI bit sets the device to 3-wire SPI mode, and a value of 0 sets the device to 4-wire SPI mode. #### INT INVERT Bit A value of 0 in the INT\_INVERT bit sets the interrupts to active high, and a value of 1 sets the interrupts to active low. #### **FULL RES Bit** When this bit is set to a value of 1, the device is in full resolution mode, where the output resolution increases with the *g* range set by the range bits to maintain a 2.9 mg/LSB scale factor. When the FULL\_RES bit is set to 0, the device is in 10-bit mode, and the range bits determine the maximum *g* range and scale factor. #### **Justify Bit** A setting of 1 in the justify bit selects left (MSB) justified mode, and a setting of 0 selects right justified mode with sign extension. #### **Range Bits** These bits set the *g* range as described in Table 20. Table 20. g Range Setting | Setting | | | |---------|----|----------------| | D1 | D0 | <i>g</i> Range | | 0 | 0 | ±1.5 g | | 0 | 1 | ±3 g | | 1 | 0 | ±3 g<br>±6 g | | 1 | 1 | ±12 g | # Register 0x32 to Register 0x37—DATAX0, DATAX1, DATAY0, DATAY1, DATAZ0, DATAZ1 (Read Only) These six bytes (Register 0x32 to Register 0x37) are eight bits each and hold the output data for each axis. Register 0x32 and Register 0x33 hold the output data for the x-axis, Register 0x34 and Register 0x35 hold the output data for the y-axis, and Register 0x36 and Register 0x37 hold the output data for the z-axis. The output data is twos complement, with DATAx0 as the least significant byte and DATAx1 as the most significant byte, where x represent X, Y, or Z. The DATA\_FORMAT register (Address 0x31) controls the format of the data. It is recommended that a multiple-byte read of all registers be performed to prevent a change in data between reads of sequential registers. Register 0x38—FIFO CTL (Read/Write) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----------|----|---------|---------|----|----|----|----| | FIFO_MODE | | Trigger | Samples | | | | | #### FIFO\_MODE Bits These bits set the FIFO mode, as described in Table 21. **Table 21. FIFO Modes** | Set | ting | | | | | | |-----|------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | D7 | D6 | Mode | Function | | | | | 0 | 0 | Bypass | FIFO is bypassed. | | | | | 0 | 1 | FIFO | FIFO collects up to 32 values and then stops collecting data, collecting new data only when FIFO is not full. | | | | | 1 | 0 | Stream | FIFO holds the last 32 data values. When FIFO is full, the oldest data is overwritten with newer data. | | | | | 1 | 1 | Trigger | When triggered by the trigger bit, FIFO holds the last data samples before the trigger event and then continues to collect data until full. New data is collected only when FIFO is not full. | | | | #### **Trigger Bit** A value of 0 in the trigger bit links the trigger event of trigger mode INT1, and a value of 1 links the trigger event to INT2. #### **Samples Bits** The function of these bits depends on the FIFO mode selected (see Table 22). Entering a value of 0 in the samples bits immediately sets the watermark status bit in the INT\_SOURCE register, regardless of which FIFO mode is selected. Undesirable operation may occur if a value of 0 is used for the samples bits when trigger mode is used. **Table 22. Samples Bits Functions** | FIFO Mode | Samples Bits Function | |-----------|-----------------------------------------------------------------------------------------| | Bypass | None. | | FIFO | Specifies how many FIFO entries are needed to trigger a watermark interrupt. | | Stream | Specifies how many FIFO entries are needed to trigger a watermark interrupt. | | Trigger | Specifies how many FIFO samples are retained in the FIFO buffer before a trigger event. | 0x39—FIFO STATUS (Read Only) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----------|----|---------|----|----|----|----|----| | FIFO_TRIG | 0 | Entries | | | | | | ### FIFO\_TRIG Bit A 1 in the FIFO\_TRIG bit corresponds to a trigger event occurring, and a 0 means that a FIFO trigger event has not occurred. #### **Entries Bits** These bits report how many data values are stored in FIFO. Access to collect the data from FIFO is provided through the DATAX, DATAY, and DATAZ registers. FIFO reads must be done in burst or multiple-byte mode because each FIFO level is cleared after any read (single- or multiple-byte) of FIFO. FIFO stores a maximum of 32 entries, which equates to a maximum of 33 entries available at any given time because an additional entry is available at the output filter of the device.