AN3468 Rev 1, 05/2009 Freescale Semiconductor Application Note The MMA745xL Digital Accelerometer by: Kimberly Tuck Inertial Applications Engineer Tempe, AZ The MMA745xL digital accelerometer is a 3 x 5 x 1 mm product that can communicate using both I2C and SPI. This device has both threshold and pulse detection interrupts. There are 2 sampling rates available at 125 Hz (using the 62.5 Hz digital filter) and 250 Hz (using the 125 Hz digital filter). There is a self test function to verify the integrity of the MEMS sensor and the ASIC signal path. Figure 1 shows the simple evaluation board for the MMA745xL which is available online. This board contains the accelerometer with all pins mapped out to a 14 pin header. The image on the left shows the ground plane which ties the digital and analog ground pins together. This is necessary to improve the noise performance based on internal trim and is the recommendation for this part. The image in the center is the front view of the board which shows all the other connections. This board can be wired to a Freescale MCU evaluation or demo board and programmed for various application functions which are described in detail below. Back View Front View Actual Image of the Board Figure 1. MMA745xL Accelerometer Simple Evaluation Board APPLICATIONS AND SENSING CAPABILITIES OF THE MMA745XL The MMA745xL is the first family of digital 3-axis consumer accelerometers that Freescale has designed. There are several sensing functions that accelerometers are capable of detecting. These are motion, freefall, shock, vibration, and tilt. The advantage of a digital accelerometer is that the A/D converter is implemented within the sensor and an MCU can be used to accompany the sensor that does not require the A/D converter. The sensor can connect directly to the SPI or I2C into the MCU. The disadvantage is that there are selected digital filters within the sensor which limits the sampling rate for certain applications. Motion Detection Typically motion detection is used to identify if an object is in use or not based on change in acceleration output. The purpose of power cycling is to try to minimize the power consumption for the application. By moving into a standby (low power) mode when the device is not in use then switching to measurement mode (active mode) which is a full power mode, the overall power consumption can be decreased. The power consumption is the same regardless of the two sampling rate options in the active modes. The MMA745xL can be put into standby mode for a set period of time consuming only 5 μA. Then the device must be programmed to switch over to measurement mode to monitor the X, Y, Z outputs to determine if a significant change in acceleration has occurred. This can be done using a timer function in the MCU. The device will not auto wake from standby mode. When in an active mode the device consumes 400-450 μA of current. The device can be power cycled between standby mode and measurement mode minimizing the overall current consumption for the application. This is useful in a wide variety of applications. It is particularly important in handheld devices which require batteries to operate. © Freescale Semiconductor, Inc., 2008-2009. All rights reserved. Hints for a Power Cycling Algorithm During a power cycling routine the device will be set to standby mode until the MCU timer triggers. Then the MCU will switch the sensor into measurement mode and take one reading from X, Y and Z. If the RMS value is a certain threshold greater than 1g or less than 1g then motion is detected and the device will stay in measurement mode. Otherwise the MCU will switch accelerometer back into standby mode. The timing will be somewhat dependant on the circumstances of the application and the tradeoff between the reaction time vs. the consumed current. Motion Detection using the MMA745xL Logic Interrupts The Level Detection mode can be used to detect motion with an interrupt. The threshold level can be set and the interrupt will occur when a motion greater than the threshold occurs. There are no timers in the Level Detection mode and false readings are possible. It is recommended to set the threshold level to 2g or greater for motion detection using the Level Detection to minimize false readings. The Pulse Detection mode can detect motion as a single pulse or as a double pulse. The threshold and the time of the pulse must be set. In pulse mode the detection occurs when X or Y or Z is greater than the set threshold within the set time window (less than the time window). It is not able to detect motion for a time period greater than a set time window. Motion detection can also be done in measurement mode sampling the X, Y and Z outputs with a set timer. This method would require programming the algorithm with the MCU. This last method would be necessary to detect a motion for greater than a set time period. Freefall Freefall is a sensing function that can be used to identify that a large impact is highly probable. This is useful in notebook computers to park the drive heads before impact and for many types of electronic equipment to shut down before impact. Freefall can also be used for warranty protection along with shock to identify how high an object has fallen to determine the approximate resultant force. For a robust algorithm there are various different freefall conditions that should be considered; linear freefall, projectile fall and rotational fall. Cheaper freefall solutions typically only consider linear freefall. Linear Freefall using the MMA745xL Logic Interrupts The MMA745xL has internal logic to detect linear freefall using either the Level Detection or the Pulse Detection modes. The Level Detection is not as robust because it does not have any timers associated with it. It simply detects any resultant output of X&&Y&&Z < Set Threshold. The Pulse Detection Freefall condition is more robust because it has a timer. The Pulse Detection freefall algorithm looks at X&&Y&&Z < Threshold for > Latency Timer. The timer in the pulse detection helps avoid false readings. Advanced Freefall Algorithm Hint Using a microcontroller to store some of the past history and to analyze the outputs linear, projectile and rotational falls can be detected using the MMA745xL to detect if any of these different conditions are occurring. Shock Shock is a sensing function of the accelerometer that is useful for warranty protection, shipping and handling and to detect the end of a fall condition. It is also used to detect tapping. Shock is a sensing function that can be difficult to detect with the consumer low-g accelerometers because shocks are typically high accelerations. The MMA745xL is capable of detecting up to 8g of acceleration. In some cases freefall can be used to determine the height of a fall using the standard Newtonian equations of motion and then back calculating for the distance. Detecting Shock using the MMA745xL Logic Interrupts The Level Detection interrupt can be used to detect shock in the same manner it is done for motion detection. The single and double pulse interrupts are the most useful for shock. Vibration Vibration sensing is limited by the digital filtering in the accelerometer. The MMA745xL has a maximum sampling rate of 250 Hz. Therefore it is capable of detecting from DC to 125 Hz of vibration. The MMA745xL is suitable for these lower frequencies. AN3468 Sensors Freescale Semiconductor 2 Tilt Tilt is used for many different applications. The cell phone and PMP market has exploded with opportunities for accelerometers to perform tilt functions. The most popular features are portrait/landscape orientation detection, scrolling, and menu selection. The two main challenges of tilt are to determine the required resolution and accuracy for the application. The MMA745xL has a maximum sensitivity of 64 counts/g. The resolution is the smallest detectable change in acceleration which is 16 mg per count. This corresponds to approximately 1.5 degrees of resolution using two axes. The accuracy is how closely the true value is equal to the measured value from the accelerometer. This is dependant on the sum of all errors from the accelerometer. Typically after calibration the accuracy is about ±4 degrees. SENSOR PLACEMENT Sensor placement is very important and is often overlooked. The MEMS sensor inside the package is very sensitive to stresses. Small deflections inside the MEMS sensor on the order of 10 nm correspond to a change in acceleration of 1g. Care must be taken to ensure that the package is not stressed by holes or components on the PCB placed too closely to the accelerometer. Please review the mounting guidelines in AN3484. It is important to not place the sensor near an edge where it may be knocked around or touched by people’s hands. Also avoid bending the PCB as the PCB stress is transferred to the accelerometer. Temperature can also be an issue. It is good to avoid placing the sensor far away from components that may have large temperature variations, or that are constantly very hot as this will also affect the offset of the sensor. For optimal motion detection, place the sensor away from the center of the device. This will ensure better acceleration readings and make them more significant to detect smaller motions, from a higher moment of inertia than if placed right on the center of movement. Connecting the MMA745xL to an MCU using I2C Communication Connecting this evaluation board to an MCU using I2C communication is simple. Connect power and ground, SDA and the SCL lines appropriately to the MCU. The 10 μF capacitors are added in case of a dirty input supply. Figure 2. I2C Communication Sensor Connections AN3468 Sensors Freescale Semiconductor 3 Figure 3. IIC Read and Write Protocol Format The MMA745xL IIC communication protocol follows the Philips Semiconductors (now NXP Semiconductors) standard. In this interface only two bus lines are required: a serial data line (SDA) and a serial clock line (SCL). Serial, 8-bit oriented bidirectional data transfers can be made at up to 100 kbit/s in the Standard-mode and up to 400 kbit/s in the fast-mode. These modes are adjustable by changing the clock frequency. The maximum allowable bus capacitance is 400 pF. Both SDA and SCL are bidirectional lines, connected to a positive supply voltage via a pull-up resistor. The recommended value is between 2.2 kΩ 4.7 kΩ The accelerometer is always considered the slave and the MCU is always considered the master. The accelerometer is not capable of stretching the clock. The benefits of the I2C Communication interface is that many ICs can be added to this bus. The only limitation is the bus capacitance. The simple 2 wire serial I2C-bus minimizes interconnections so ICs have fewer pins and there are not as many PCB traces, resulting in smaller and less expensive PCBs. Each device is recognized by a unique address (whether it is a microcontroller, memory or an accelerometer). The MMA7455L has an extra address bit to allow for two different addresses available but the address pin on this sensor has been disabled. This device is addressed by $1D only. The IADDR0 pin is enabled on the MMA7458L, which will be available in Q4 2008. AN3468 Sensors Freescale Semiconductor 4 The following are four simple rules of the IIC bus to be aware of: 1. The SDA (data) and SCL (clock) cannot actively be driven high by any I2C device. I2C devices must use open-drain drivers. The logic is high by using the recommended external pull-up resistors. 2. The information on the data line is only read on the high phase of the clock. 3. Changing the level of the data is only allowed in the low phase of the clock except during start or stop conditions and this is how these events are signified. 4. When the bus is not busy SDA and SCL lines are pulled back to logic “1”. For more detailed information on the I2C protocol please refer to the NXP Semiconductor IIC bus specification and user manual available online. BASIC START-UP PROCEDURE The following are some simple steps to set up the accelerometer using IIC. 1. Set up the microcontroller hardware shown above for IIC communication. 2. Configure the clock speed and all the pins required. The speed is set by adjusting the baud rate. 3. Write simple single byte Read and Write command to communicate to the device. The example below was done using the MC9S08QE hardware controller for the IIC. 4. Write to the MMA745xL Register $16, sending in a value of 0x05 to set up the device for measurement mode with ±2g dynamic range. 5. Read the Control Register $16 to ensure that the value is correct (0x05). 6. Read the X, Y and Z registers and watch the outputs change. Example Code for Start-up Using IIC The following code has been written with a Freescale S08 MCU using the embedded IIC module. This software is for the host side. //--------------------------------------------------------------------------------// HW I2C driver embedded I2C module using FSL MC9S08QE K. Tuck #define IIC_WriteAdr 0x1D // $1D shifted in with a 0 had been $3A #define IIC_ReadAdr 0x1D // $1D shifted in with a 1 had been $3B //Function Definitions void MCU_init(void); // From Device initialization void Delay(byte count); void IIC_SingleByteWrite(unsigned char reg, unsigned char val); char IIC_SingleByteRead(unsigned char reg); // global variables char Xdata=0; char Ydata=0; char Zdata=0; char ControlRegVal=0; unsigned char ACK, write1; //-----------------------------------------------------------------------//Main void main(void) { MCU_init(); IIC2C1_MST = 0; Delay(0xFF); IIC2C1_MST = 1; // create start Delay(0xFF); IIC2C1_MST = 0; // create stop Delay(0xFF); / //IIC_SingleByteWrite(0x16,0x05); // Put ION into Measurement Mode Delay(0xFF); ControlRegVal=0; Xdata=0; Ydata=0; AN3468 Sensors Freescale Semiconductor 5 Zdata=0; ControlRegVal= IIC_SingleByteRead(0x16); //Read back out the value of Register 16, make sure it is 5 // Read X, Y, and Z forever for(;;) { Delay(0xFF); Xdata=IIC_SingleByteRead(0x06); // Read X Register Delay(0xFF); Ydata=IIC_SingleByteRead(0x07); // Read Y Register Delay(0xFF); Zdata=IIC_SingleByteRead(0x08); // Read Z Register } for(;;) { /* __RESET_WATCHDOG(); by default, COP is disabled with device init. When enabling, also reset the watchdog. */ } /* loop forever */ /* please make sure that you never leave main */ } //------------------------------------------------------------------------//------------------------------------------------------------------------//Simple Delay Function void Delay(byte count) { byte i; for (i=0; i<count; i++) { } } //--------------------------------------------------------------------------// This is the I2C byte write function void IIC_SingleByteWrite(unsigned char reg, unsigned char val) { IIC2C1_IICEN=1; IIC2C1_TX=1; IIC2C1_MST=1; //Sends Start; IIC2D = (IIC_WriteAdr<<1); // send the accelerometer address while (IIC2S_IICIF==0);//Waiting for transmission to complete Delay(100); IIC2S_IICIF=1; Delay(100); if (IIC2S_RXAK==1){ IIC2C_MST=0; //send stop ACK=0; while(1); } else{ ACK=1; } IIC2D = reg; //write in the register address while (IIC2S_IICIF==0 );//Waiting for transmission to complete IIC2S_IICIF=1; if (IIC2S_RXAK==1){ IIC2C1_MST=0; //send stop ACK=0; while(1); } else{ ACK=1; } IIC2D = val; // send the data to be written while (IIC2S_IICIF==0);//Waiting for transmission to complete AN3468 Sensors Freescale Semiconductor 6 IIC2S_IICIF=1; if (IIC2S_RXAK==1){ IIC2C_MST=0; //send stop ACK=0; while(1); } else{ ACK=1; } IIC2C1_MST=0; write1=1; } //-----------------------------------------------------------------------------//-----------------------------------------------------------------------------// This is the I2C byte read function char IIC_SingleByteRead(unsigned char reg) { char data; IIC2C1_IICEN=1; IIC2C1_TX=1; IIC2C1_MST=1; //Sends Start; IIC2D = (IIC_WriteAdr<<1); // send the accelerometer address Delay(0x50); while (IIC2S_IICIF==0);//Waiting for transmission to complete IIC2S_IICIF=1; if (IIC2S_RXAK==1){ IIC2C_MST=0; //send stop ACK=0; while(1); } else{ ACK=1; } IIC2D = reg; //write in the register address Delay(0x50); //Check_ACK(); //check ACK while (IIC2S_IICIF==0);//Waiting for transmission to complete IIC2S_IICIF=1; if (IIC2S_RXAK==1){ IIC2C_MST=0; //send stop ACK=0; while(1); } else{ ACK=1; } //Sending a Restart, the device Address with a Read IIC2C1_TX=1; IIC2C1_RSTA=1; //Sends Start; IIC2D =(IIC_ReadAdr<<1)|0x01; // Send the accelerometer device address with the Read Bit //Delay(100); //Check_ACK(); //check ACK while (IIC2S_IICIF==0);//Waiting for transmission to complete IIC2S_IICIF=1; if (IIC2S_RXAK==1) { IIC2C_MST=0; //send stop ACK=0; while(1); } else{ AN3468 Sensors Freescale Semiconductor 7 ACK=1; } IIC2C1_TX=0; // Change over to Receiver Mode IIC2C_TXAK = 1; // send NACK in the next read data=IIC2D; //dummy read while (IIC2S_IICIF==0); IIC2S_IICIF=1; // wait until the transmission ends data = IIC2D; //This is the real Read command while (IIC2S_IICIF==0); // wait until the transmission ends IIC2S_IICIF=1; //Clear the interrupt flag IIC2C1_MST = 0; // send a stop, leave master mode return(data); } //--------------------------------------------------------------------------- General Pseudo Code Using IIC The following is general IIC code based on work by V.Himpe1. n, x = general BYTE SIZE = max number DATA(SIZE) = an array holding up to SIZE number of bytes. This will contain the data transmitted and store received data. BUFFER = a byte value holding immediate received or transmit data. / $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$ / / **** I2C Driver General I2C Pseudo Code Released as Public Domain **** / / $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$ / DECLARE N,SIZE,BUFFER,X Byte DECLARE DATA() Array of SIZE elements SUBroutine I2C_INIT / call this immediately after power-on / SDA=1 SCK=0 FOR n = 0 to 3 CALL STOP NEXT n ENDsub SUBroutine START SCK=1 SDA=1 SDA=0 SCK=0 SDA=1 ENDsub SUBroutine STOP SDA=0 SCK=1 SDA=1 ENDsub SUBroutine PUTBYTE(BUFFER) FOR n = 7 TO 0 SDA= BIT(n) of BUFFER SCK=1 SCK=0 NEXT n SDA=1 ENDsub SUBroutine GETBYTE FOR n = 7 to 0 SCK=1 BIT(n) OF BUFFER = SDA 1. http://www.esacademy.com/faq/i2c/general/i2cpseud.htm AN3468 Sensors Freescale Semiconductor 8 SCK=0 NEXT n SDA=1 ENDsub SUBroutine GIVEACK SDA=0 SCK=1 SCK=0 SDA=1 ENDsub SUBroutine GETACK SDA=1 SCK=1 WAITFOR SDA=0 SCK=0 ENDSUB / this concludes the low-level set of instructions for the I2C driver The next functions will handle the telegram formatting on a higher level / SUBroutine READ(Device_address,Number_of_bytes) Device_adress=Device_adress OR (0000.0001)b /This sets the READ FLAG/ CALL START CALL PUTBYTE(Device_adress) CALL GETACK FOR x = 0 to Number_of_bytes CALL GETBYTE DATA(x)=BUFFER /Copy received BYTE to DATA array / IF X< Number_of_bytes THEN /Not ack the last byte/ CALL GIVEACK END IF NEXT x CALL STOP ENDsub SUBroutine WRITE(Device_address,Number_of_bytes) Device_adress=Device_adress AND (1111.1110)b / This clears READ flag / CALL START CALL PUTBYTE(Device_adress) CALL GETACK FOR x = 0 to Number_of_bytes CALL PUTBYTE (DATA(x)) CALL GETACK NEXT x CALL STOP ENDsub SUBroutine RANDOMREAD(Device_adress,Start_adress,Number_of_bytes) Device_adress=Device_adress AND (1111.1110)b / This clears READ flag / CALL START CALL PUTBYTE(Device_adress) CALL GETACK CALL PUTBYTE(Start_adress) CALL GETACK CALL START /create a repeated start condition/ Device_adress=Device_adress OR (0000.0001)b /This sets the READ FLAG/ CALL PUTBYTE(Device_adress) CALL GETACK FOR x = 0 to Number_of_bytes CALL GETBYTE DATA(x)=BUFFER CALL GIVEACK NEXT x CALL STOP ENDsub AN3468 Sensors Freescale Semiconductor 9 For further information and examples using the QE128 Freescale S08 with the MMA745xL there is an example with a SW implementation of the driver available in the following software application notes on-line. • AN3479SW: shows the programming required to communicate to the device using the IIC bus. • AN3468SW: has examples of using measurement mode, level mode and pulse detection. • AN3571SW: shows different settings for using either the level or the pulse detection mode Connecting the MMA745xL to an MCU using SPI Communication When connecting the sensor to the MCU using SPI communications there are 6 connections into the MCU. These connections are power, ground, the clock (SPSCK), MOSI (data), MISO (data) and CS which is the slave select line. The 10 μF caps are added as an extra precaution in case of a dirty supply input. Figure 4. SPI Communication Sensor Connections Figure 5. SPI Timing Diagrams AN3468 Sensors Freescale Semiconductor 10 SPI communication can be implemented using 4 lines: MOSI (master-output/slave-input), MISO (master-input/slave-output), SS (slave select), and SPSCK (SPI serial clock). The master device initiates all SPI data transfers. During a transfer, the master shifts data out (on the MOSI pin) to the slave while simultaneously shifting data in on the MISO pin from the slave (SDO). The transfer effectively exchanges the data that was in the SPI shift registers of the two SPI systems. The SPSCK signal is a clock output from the master and an input to the slave. The slave device must be selected by a low level on the slave select input (CS pin). The MMA745xL is in SPI 4 wire mode by default. Register $16 contains a bit labeled SPI3W, which is set to 0 by default for 4 wire mode. SPI communication can also be implemented using 3 lines: MIMO (master-in/master-out), SS (slave select), SPSCK (SPI serial clock). The SDA/I/O line on the MMA745xL changes from being an input into the accelerometer and becomes a bidirectional line. To set up the sensor for 3 wire SPI communication bit SPI3W in Register $16 (Control Register 1) must be set to 1. For four wire SPI mode SPI3W is set to 0. The following example shows how to set up the register in either mode and into 2g measurement mode. WriteRegister (0x16, 0x25) to set the accelerometer into SPI 3 wire mode 2g measurement mode. WriteRegister (0x15, 0x05) to set the accelerometer into SPI 4 wire mode 2g measurement mode. When using the SPI bus the register value is sent with the first value being a 1 to indicate write or 0 to indicate a read command. Note this is opposite from the IIC R/W bit. The address is 6 bits, followed by a “Don’t Care” bit, which has no meaning to the slave. For example to send a read command the 6-bit register data is simply shifted left 1 bit. (SPI2D=((reg &0x3F)<<1);). For a write command the first bit is a 1. SPI2D=(((reg &0x3F)<<1)|0x80); The SPI clock speed of the sensor can go up to 4 MHz which is configured by the baud rate chosen in the MCU. This is the maximum achievable speed when DVdd is less than 2.4 V. When DVdd is greater than 2.4 V up to 8 MHz is achievable. BASIC START-UP PROCEDURE The following are some simple steps to set up the accelerometer with an MCU for the SPI communication. 1. Set-up the microcontroller hardware shown in Figure 4 for SPI communication. 2. Configure the clock speed and all the pins required. The speed is set by adjusting the baud rate. 3. Write simple single byte Read and Write command to communicate to the device. The example below was done using the hardware controller for the SPI. 4. Write to the MMA745xL Register $16, sending in a value of 0x05 to set up the device for measurement mode with ±2g dynamic range. 5. Read the Control Register $16 to ensure that the value is correct (0x05). 6. Read the X, Y and Z registers and watch the outputs change. Example Code for Start-up Using SPI The following example code was developed with a Freescale S08 MCU using the embedded SPI module. This software is for the host side. This example shows the code for both 4Wire Mode and 3Wire Mode. The MCU can be initialized for 3 Wire Mode or for 4 Wire Mode and the following code will execute. //--------------------------------------------------------------------------------// HW SPI driver embedded SPI module using FSL S08QE MCU K. Tuck //--------------------------------------------------------------#define CS PTDD_PTDD3 byte Xdata,Ydata,Zdata,CTLReg; void MCU_init(void); /* Device initialization function declaration */ byte spi_read(byte reg); void spi_write(byte reg, byte data); void main(void) { MCU_init(); /* call Device Initialization */ PTDD_PTDD3=1; //CS Pin description PTDDD_PTDDD3=1; Xdata=0; CTLReg=0; //Set up sensor for SPI 3 Wire Mode or 4 Wire Mode by writing to SPI3W in Register $16 spi_write(0x16,0x25); //3 Wire Mode Set up in the Accelerometer // spi_write(0x16,0x05); //4 Wire Mode Set up in the Accelerometer CTLReg=spi_read(0x16); // Read back the value that has been set for the Mode for (;;){ Xdata=spi_read(0x06); //Read X,Y,Z outputs from Sensor Ydata=spi_read(0x07); AN3468 Sensors Freescale Semiconductor 11 Zdata=spi_read(0x08); } for(;;) { /* __RESET_WATCHDOG(); by default, COP is disabled with device init. When enabling, also reset the watchdog. */ } /* loop forever */ /* please make sure that you never leave main */ } //-----------------------------------------------------------------------------------------// Function Definitions for Read and Write // Read function SPI 3 Wire Mode or 4 Wire Mode byte spi_read(byte reg){ byte x; CS=0; x=SPI2S; x=SPI2D; while (!SPI2S_SPTEF); SPI2D= ((reg &0x3F)<<1); // write in the register address with the read command while(!SPI2S_SPRF); //wait for transfer x=SPI2D; SPI2C2_BIDIROE = 0; // MOSI become input when 3 wire mode SPI2D = 0x00; // send 2nd byte while (!SPI2S_SPRF); // wait transfer done x = SPI2D; SPI2C2_BIDIROE = 1; //change direction back to output when in 3 wire mode CS=1; return (x); } //-----------------------------------------------------------------------------------------//Write function SPI 3 Wire or SPI 4 Wire Mode void spi_write(byte reg, byte data){ byte x; CS=0; SPI2D=(((reg &0x3F)<<1)|0x80); while (!SPI2S_SPRF); //wait for transmission complete x=SPI2D; //dummy read SPI2D=data; while (!SPI2S_SPRF); //wait for transmission complete x=SPI2D; CS=1; } //------------------------------------------------------------------------------------------ General Pseudo Code using SPI This is pseudo code for general communication. 1. 2. 3. 4. 5. 6. SS = 0 Slave Select is cleared Assert MOSI most significant bit Toggle the clock Shift the next data bit onto the MOSI pin Repeat 3 and 4 until done SS = 1 Slave Select is set For further examples using the SPI SW protocol please refer to the following application notes which should be available on the website. These examples use the basic evaluation board shown in Figure 1 with the MC9S08QE128, or with the HCS08GB60 MCU development boards. • AN3468SW: has examples of using measurement mode, level mode and pulse detection. • AN3480SW: shows the programming required to communicate to the device using the SPI bus. • AN3571SW: shows different settings for using either the level or the pulse detection mode AN3468 Sensors Freescale Semiconductor 12 PROGRAMMING THE MMA745XL This section focuses on explaining all the available features of the device which are all accessible by reading and writing to the 32 registers of the MMA745xL. Figure 6 is a screen shot of an evaluation interface for this device. This GUI uses the MMA745xL with the MC9S08QE8 microcontroller on a small 1” x 1” board which connects through SCI to USB to the computer. This demo board and software is available as part of the Sensors Toolbox (LFSTBEB7456). It displays the 3-axis output on a scope screen to view motion of the different axes. All the different settings and operation modes of the device are displayed on the menu buttons or sliders. On the right hand side all the useful registers of the device are displayed. This allows the user to view how the registers change when different settings are changed. . Figure 6. MMA745xL Evaluation Software Interface OPERATION MODES OF THE MMA745XL ACCELEROMETER Figure 7. Operation Modes of the MMA745xL All modes of the device are controlled in the mode control register (MCTL). Figure 7 displays the different modes of the MMA745xL. The following are the bits in the register and the different modes that the device can be set. $16 MCTL LPEN DRPD SPI3W STON GLVL[1] GLVL[0] MOD[1] MOD[0] Standby mode is a low power mode consuming less than 5 μA. This mode is used when the sensor is not needed to take new data. In standby mode the sensor can read and write to the registers and the other sensor detection modes are easily enabled. AN3468 Sensors Freescale Semiconductor 13 Standby Mode: RegisterWrite (0x16, 0x00) In measurement mode the device can be set up for 3 different dynamic ranges (2g, 4g and 8g). With the 8g dynamic range 8bit or 10-bit data is available. The 2g and 4g ranges are only 8-bit data. The 10-bit data is available by reading X: $00-01, Y$0203 and Z$04-05. In 2g mode and 4g mode the 10-bit data will match the 8-bit data. In 8g mode the 10-bit data is going to be 4 times that of the 8-bit data. Measurement Mode: RegisterWrite (0x16,0x01) Dynamic Range Settings: In Measurement Mode 2g: RegisterWrite(0x16, 0x05) 4g RegisterWrite (0x16,0x09) 8g RegisterWrite (0x16,0x01) Level Detection Mode: RegisterWrite (0x16, 0x02) Note: Dynamic range setting is automatically 8g. Pulse Detection Mode: RegisterWrite (0x16, 0x03) Note: Dynamic range setting is automatically 8g. CALIBRATION OF THE MMA745XL The offset can be calibrated by storing the offset values in the designated offset drift registers $10 to $15 in the accelerometer. These values will be stored until the part loses power and therefore it is a good idea to store these values in the memory of a microcontroller, used in conjunction with the sensor. This will provide automatic calibration of the sensor each time the sensor is turned back on. In order to calibrate the MMA745xL 0g offset, the predetermined digital offset values should be subtracted from the reading of the actual digital sensing values. The following procedure is a recommendation for how this can be accomplished: Step 1. After power up, set up the “Mode Control Register”(Register $16) to be in “measurement mode” by writing $05 into Register $16. Then read the X, Y and Z offset values from the Registers $00-$08. The first 6 registers of the 9 are 10-bit XYZ output values: LSB, first; MSB, second. Please verify with the data sheet for detailed register information. Step 2. In this step, the offset compensation is calculated to shift the offset to zero. For example, if the 0g offset is calibrated flat (where X = 0g, Y = 0g and Z = +1g) in 2g mode (64 LSB/g sensitivity), the outputs from Registers $00-$08 might be the following: X = +18,Y = -20, Z = +44. In this case, • X must be shifted by -18 to get X back to zero • Y must be shifted by +20 to get to zero • Z must be shifted by (+64 - 44) = +20 to get to +64 (since Z is in the +1g orientation) If the register values in the X = 0g, Y = 0g and Z = +1g orientation are the following: Step 3. These compensation values can be written in hexadecimal into the “Offset Drift Registers” $10-$15.The Offset Drift Registers require each value to be ½ LSB, therefore the calibration values calculated in Step 2. must be multiplied by two. Note that there will still be a bit of offset shift, and you may need to multiply by a bit more than two to exactly subtract the offset. If the register values in the X = 0 g, Y = 0g and Z = +1g orientation are the following: X = +18, Y = -20, Z = +44 Write -36 (DC Hex) into the X drift Register $10 Write +40 (28 Hex) into the Y drift Register $12 Write +40 (28 Hex) into the Z drift Register, $14 If the compensation requires negative values, remember that 2’s complement is always used in hexadecimal for storing the signed value as was done for the X-axis above. If using 10-bit mode, and the calibrated values are greater than 8 bits, then there is another register for up to 3 more bits: • Register $10 and $11 are for X • Register $12 and $13 are for Y • Register $14 and $15 are for Z These registers follow signed byte data using 2’s complement. Reading or writing low byte (X, Y or Z) OUTL latches high byte data (X, Y, or Z) OUTH to allow coherent 10-bit reads or writes. (X, Y, or Z) OUTH should be read/written directly following (X, Y or Z) OUTL. AN3468 Sensors Freescale Semiconductor 14 Step 4. After this compensation process is complete, you can continue to modify the values by overcompensating until you get the final output to be right at 0 for X and Y and at 64 for Z. Note this is an iterative process. Step 5. The calibrated values are stored in the “Offset Drift Registers”. To avoid the values being erased when the power is turned off, it is recommended to store these values in flash or a nonvolatile memory in the main processor or external to the processor. It is also recommended to include a short start-up sequence to write the compensation values stored in flash or nonvolatile memory to the registers $10-$15 in the accelerometer on start-up. If a microcontroller is used, a recursive program is available to auto-calibrate the device. To set the 0g offset the following recursive program can be written as a routine in the software. Place the part flat in the X = 0g, Y = 0g, Z = 1g orientation. The following is an example of the code to do an auto-calibration routine. signed char Xdata,Ydata,Zdata; signed short Xcal,Xcalp, Ycal, Ycalp, Zcal, Zcalp; byte Xcal_L, Xcal_H, Ycal_L,Ycal_H, Zcal_L, Zcal_H; void main (void){ //Initialization code for the MCU connections and accelerometer MCU_and_MMA745xL_demo_Init(); //Put the device in 2g Measurement Mode IIC_ByteWrite(0x16,0x05); //Assure that the calibration registers are cleared (not necessary) IIC_ByteWrite(0x10,0); IIC_ByteWrite(0x11,0); Xcal=0; for (;;) { Xdata=IIC_ByteRead(0x06); //Read X, Y,Z Ydata=IIC_ByteRead(0x07); Zdata=IIC_ByteRead(0x08); Xcal+= -2*Xdata; //Calculate out the calibration Value based on current Data Ycal+= -2*Ydata; if (Zdata>65){Zcal+=(Zdata-64)*2;} else{Zcal+=(64-Zdata)*2;} Xcalp=Xcal; //If calp is "positive" it is assigned to cal variable if (Xcalp<0) Xcalp +=2048; //If Negative value then convert for 2's complement Ycalp=Ycal; if(Ycalp<0) Ycalp+=2048; Zcalp=Zcal; if(Zcalp<0) Zcalp+=2048; Xcal_L= (byte)(Xcalp&0x00FF); //shift low byte to lower 8 bits Xcal_H= (byte)((Xcalp&0xFF00)>>8); //shift high byte to upper 8 bits Ycal_L= (byte)(Ycalp&0x00FF); //shift low byte to lower 8 bits Ycal_H= (byte)((Ycalp&0xFF00)>>8); //shift high byte to upper 8 bits Zcal_L= (byte)(Zcalp&0x00FF); //shift low byte to lower 8 bits Zcal_H= (byte)((Zcalp&0xFF00)>>8); //shift high byte to upper 8 bits Xcal += -2*Xdata; Delay (0xFF); Xdata=RegisterRead(0x00); } IIC_ByteWrite(0x10,Xcal_L); //Write low calibration value to the low calibration register IC_ByteWrite(0x11,Xcal_H); //Write high calibration value to the high calibration register IIC_ByteWrite(0x12,Ycal_L); //Write low calibration value to the low calibration register IIC_ByteWrite(0x13,Ycal_H); //Write high calibration value to the high calibration register IIC_ByteWrite(0x14,Zcal_L); //Write low calibration value to the low calibration register IIC_ByteWrite(0x15,Zcal_H); //Write high calibration value to the high calibration register MCU_Delay100us(100); } //Delay before rereading to ensure that values are written } AN3468 Sensors Freescale Semiconductor 15 SETTING UP THE SAMPLING FREQUENCY AND SELF TEST To set the bandwidth filter to 62.5 Hz the sampling frequency will be 125 Hz. Clear DFBW in Control Register 1. RegisterWrite (0x18,regs[0x18] & 0xEF) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 0 1 1 1 1 1 1 1 $18 result 0 THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN To set the bandwidth filter to 125 Hz the sampling frequency will be 62.5 Hz. Set DFBW in Control Register 1. RegisterWrite (0x18,regs[0x18] | 0x80) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 1 0 0 0 0 0 0 0 $18 result 1 THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN To verify the self test. Set STON in Mode Control Register $16. Clear STON to turn off self test. RegisterWrite(0x16, regs[0x16] ^ 0x10) $16 MCTL LPEN DRPD SPI3W STON GLVL[1] GLVL[0] MOD[1] MOD[0] $16 mask 0 0 0 1 0 0 0 0 $16 result LPEN DRPD SPI3W ~STON GLVL[1] GLVL[0] MOD[1] MOD[0] SETTING UP INT1 AND INT2 INTERRUPT REGISTERS This section explains how to set up the interrupt pins in all possible configurations. The interrupt registers are set up in the Control 1 (CTL1) Register to determine which interrupt is assigned to Level detection and which is assigned to Pulse detection. Figure 8 displays the different options for setting up the interrupt pins. Figure 8. Setting up the Interrupt Registers for Level and Pulse Detection INT1 reg = Level and INT2 reg = Pulse RegisterWrite(0x18, regs[0x18]&0xF9) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 1 1 1 1 1 0 0 1 $18 result DFBW THOPT ZDA YDA XDA 0 0 INTPIN INT1 reg = Pulse and INT2 reg = Level RegisterWrite(0x18,(regs[0x18]&0xFB)|0x02) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 1 1 1 1 1 0 1 1 $18 result DFBW THOPT ZDA YDA XDA 0 1 INTPIN AN3468 Sensors Freescale Semiconductor 16 INT1 reg = Single Pulse and INT2 reg = Pulse RegisterWrite(0x18,(regs[0x18]&0xFD)|0x04) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 1 1 1 1 1 1 0 1 $18 result DFBW THOPT ZDA YDA XDA 1 0 INTPIN INT1pin assigned to DRDY This pin can be set to allow INT1 to be used to indicate when data is ready from the sensor. RegisterWrite(0x16, reg[0x16]^0x40) $16 MCTL LPEN DRPD SPI3W STON GLVL[1] GLVL[0] MOD[1] MOD[0] $16 mask 0 1 0 0 0 0 0 0 $16 Result LPEN ~DRPD SPI3W STON GLVL[1] GLVL[0] MOD[1] MOD[0] INT1pin assigned to INT1 Reg (INT2pin = INT2 Reg) RegisterWrite(0x18, regs[0x18]&FE) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 1 1 1 1 1 1 1 0 $18 result DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] 0 INT1pin assigned to INT2 Reg (INT2pin = INT1 Reg) RegisterWrite(0x18, regs[0x18] | 0x01) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 0 0 0 0 0 0 0 1 $18 result DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] 1 LEVEL DETECTION MODE Level detection mode is capable of detecting both motion and freefall. There are no timers associated with the level detection. The OR logic is used for motion detection and the AND logic is used for freefall detection. Then there is signed threshold detection (+ or -) or absolute (+ and -). Figure 9. Level Detection Settings AN3468 Sensors Freescale Semiconductor 17 These are the following available options for Level Detection Mode and how they can be enabled. For motion or for freefall detection there is an absolute condition that can be used. RegisterWrite(0x18,regs[0x18]&0xBF) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 1 0 1 1 1 1 1 1 $18 result DFBW 0 ZDA YDA XDA INTRG[1] INTRG[0] INTPIN For motion detection there is a positive/negative detection condition that can be used. RegisterWrite(0x18,regs[0x18]|0x40) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 0 1 0 0 0 0 0 0 $18 result DFBW 1 ZDA YDA XDA INTRG[1] INTRG[0] INTPIN For motion detection only there is an or logic condition that can be used. LDPL = 0 RegisterWrite (0x19,regs[0x19]&0xFE) $19 CTL2 — — — — — DRVO PDPL LDPL $19 mask 1 1 1 1 1 1 1 0 $19 Result — — — — — DRVO PDPL 0 For freefall detection only there is an and logic condition that can be used. LDPL = 1 RegisterWrite1(0x19,regs[0x19]|0x01) $19 CTL2 — — — — — DRVO PDPL LDPL $19 mask 0 0 0 0 0 0 0 1 $19 result — — — — — DRVO PDPL 1 This is an example of how to toggle the XDA bit to enable or disable the X-axis. RegisterWrite1(0x18,regs[0x18]^0x08) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 0 0 0 0 1 0 0 0 $18 result DFBW THOPT ZDA YDA ~XDA INTRG[1] INTRG[0] INTPIN This is an example of how to toggle the YDA bit to enable or disable the Y-axis. RegisterWrite1(0x18,regs[0x18]^0x10) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 0 0 0 1 0 0 0 0 $18 result DFBW THOPT ZDA ~YDA XDA INTRG[1] INTRG[0] INTPIN This is an example of how to toggle the ZDA bit to enable or disable the Z-axis. RegisterWrite1(0x18,regs[0x18]^0x20) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 0 0 1 0 0 0 0 0 $18 result DFBW THOPT ~ZDA YDA XDA INTRG[1] INTRG[0] INTPIN AN3468 Sensors Freescale Semiconductor 18 This is the register for setting the threshold value. Table 1 shows the hex values with the associated counts and g-values to understand how to program in the level value that corresponds to the acceleration threshold desired. $1A LDTH LDTH[7] LDTH[6] LDTH[5] LDTH[4] LDTH[3] LDTH[2] LDTH[1] LDTH[0] In Threshold Detection Mode the sensitivity is 16 counts/g. The threshold is set in the LDTH $1A 8-bit Register. Table 1. Setting Threshold Values Binary Hex Decimal Counts g-value 0000 0000 0x00 0 0 0g 0001 0000 0x10 16 16 1g 0010 0000 0x20 32 32 2g 0011 0000 0x30 48 48 3g 0100 0000 0x40 64 64 4g 0101 0000 0x50 80 80 5g 0110 0000 0x60 96 96 6g 0111 0000 0x70 112 112 7g 0111 1111 0x7F 127 127 8g 1000 0000 0x80 -128 128 -8g 1001 0000 0x90 -112 144 -7g 1010 0000 0xA0 -96 160 -6g 1011 0000 0xB0 -80 176 -5g 1100 0000 0xC0 -64 192 -4g 1101 0000 0xD0 -48 208 -3g 1110 0000 0xE0 -32 224 -2g 1111 0000 0xF0 -16 240 -1g 1111 1111 0xFF -1 255 0g AN3468 Sensors Freescale Semiconductor 19 Optimal Settings for Freefall using Level Detection For optimal settings for the freefall using Level Detection choose the following settings: • • • • Absolute Logic (THOPT) X, Y, and Z must be enabled (ZDA, YDA, XDA) Negative AND Logic (LDPL = 1) LDTH: Level Detection Threshold = 0x03 = 0.19g 1. THOPT = 0 Absolute Condition 2. ZDA = 0 Enable Z, YDA = 0 Enable Y, XDA = 0 Enable X RegisterWrite(0x18,regs[0x18]&0x87) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 1 0 0 0 0 1 1 1 $18 result DFBW 0 ZDA YDA XDA INTRG[1] INTRG[0] INTPIN 3. Negative AND Logic Set LDPL RegisterWrite(0x19,regs[0x19]|0x01) $19 CTL2 — — — — — DRVO PDPL LDPL $19 mask 0 0 0 0 0 0 0 1 $19 Result — — — — — DRVO PDPL 1 LDTH[7] LDTH[6] LDTH[5] LDTH[4] LDTH[3] LDTH[2] LDTH[1] LDTH[0] 4. Set Threshold = 0.19 g RegisterWrite(0x1A,0x03) $1A LDTH Set the threshold to 3 counts (3/16 = 0.1875 g). AN3468 Sensors Freescale Semiconductor 20 Optimal Settings for Motion using Level Detection For optimal settings for the motion using Level Detection choose the following settings: • • • • Absolute Logic (THOPT) X, Y enabled (YDA, XDA) with Z disabled Positive OR Logic (LDPL = 0) LDTH: Level Detection Threshold = 0x20 (2g) 1. THOPT=0 Absolute Condition 2. ZDA=1 Disable Z, YDA=0 Enable Y, XDA=0 Enable X RegisterWrite(0x18,((regs[0x18]&0x87) | 0x20) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 1 0 1 0 0 1 1 1 $18 result DFBW 0 ZDA YDA XDA INTRG[1] INTRG[0] INTPIN 3. Positive OR Logic Clear LDPL RegisterWrite(0x19,regs[0x19]&0xFE) $19 CTL2 — — — — — DRVO PDPL LDPL $19 mask 1 1 1 1 1 1 1 0 $19 result — — — — — DRVO PDPL 0 LDTH[7] LDTH[6] LDTH[5] LDTH[4] LDTH[3] LDTH[2] LDTH[1] LDTH[0] 4. Set Threshold to 2g RegisterWrite(0x1A,0x20) $1A LDTH Set the threshold to 32 counts (32/16 = 2 g). AN3468 Sensors Freescale Semiconductor 21 PULSE DETECTION MODE Pulse detection mode is capable of detecting both motion and freefall. There are timers associated with the pulse detection. The OR logic is used for motion detection where either a single or a double pulse can be detected. For motion detection the logic is set up to detect an event when a programmed “Threshold” has been reached for < Time Window. It is not possible to set up motion detection for Threshold reached for > Time Window. The AND logic is used for freefall detection. In this case when below the set “Threshold” for > Latency Timer the Pulse Detection flag is set. Figure 10. Pulse Mode Settings The following are all the available settings that can be used in the pulse detection mode. For the OR logic used for single or double pulse detection, the following register should be set with PDPL = 0. RegisterWrite(0x19,regs[0x19]&0xFD) $19 CTL2 — — — — — DRVO PDPL LDPL $19 mask 1 1 1 1 1 1 0 1 $19 result — — — — — DRVO 0 LDPL For the AND logic used for pulse freefall detection, the following register should be set with PDPL=1. RegisterWrite(0x19,regs[0x19]|0x02) $19 CTL2 — — — — — DRVO PDPL LDPL $19 mask 0 0 0 0 0 0 1 0 $19 result — — — — — DRVO 1 LDPL This is an example of how to toggle the XDA bit to enable or disable the X-axis. RegisterWrite(0x18,regs[0x18]^0x08) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 0 0 0 1 0 0 0 0 $18 result DFBW THOPT ZDA 1 XDA INTRG[1] INTRG[0] INTPIN This is an example of how to toggle the YDA bit to enable or disable the Y-axis. RegisterWrite(0x18,regs[0x18]^0x10) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 0 0 0 1 0 0 0 0 $18 result DFBW THOPT ZDA 1 XDA INTRG[1] INTRG[0] INTPIN AN3468 Sensors Freescale Semiconductor 22 This is an example of how to toggle the ZDA bit to enable or disable the Z-axis. RegisterWrite(0x18,regs[0x18]^0x20) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 0 0 1 0 0 0 0 0 $18 result DFBW THOPT 1 YDA XDA INTRG[1] INTRG[0] INTPIN PDTH[3] PDTH[2] PDTH[1] PDTH[0] This is the pulse detection threshold value that can be set according to Table 1. $1B PDTH PDTH[7] PDTH[6] PDTH[5] PDTH[4] This register defines the pulse width of the first pulse window. The pulse duration increments in ½ ms values, so every count is ½ ms. The total range is from 0 - 127.5 ms. $1C PW PD[7] PD [6] PD [5] PD [4] PD [3] PD [2] PD [1] PD [0] This register defines the latency time, which is the time in between pulses for double pulse, or the amount of time to trigger a freefall condition. The scale increases from 0 ms - 255 ms 0x00-0xFF. Every count is equal to 1 ms. $1D LT LT[7] LT [6] LT [5] LT [4] LT [3] LT [2] LT [1] LT [0] This is the timing window for the second pulse when setting up the double pulse condition. The scale is in ms increments from 0 ms - 255 ms 0x00-0xFF. $1E TW TW[7] TW [6] TW [5] TW [4] TW [3] TW [2] TW [1] TW [0] Optimal Settings for Single Pulse Detection • • • • Positive OR logic: PDPL = 0 X, Y, Z enabled PDTH = 0x40 (4g) PD = 0x10 1. Positive OR Logic PDPL = 0 RegisterWrite(0x19,regs[0x19]&0xFD) $19 CTL2 — — — — — DRVO PDPL LDPL $19 mask 1 1 1 1 1 1 0 1 $19 result — — — — — DRVO 0 LDPL 2. X, Y, Z enabled RegisterWrite1(0x18,regs[0x18]&0x87) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 1 0 0 0 0 1 1 1 $18 result DFBW 0 0 0 0 INTRG[1] INTRG[0] INTPIN 3. PDTH (Pulse Threshold) set to 4g RegisterWrite(0x1B,0x40) $1B PDTH PDTH[7] PDTH[6] PDTH[5] PDTH[4] PDTH[3] PDTH[2] PDTH[1] PDTH[0] $1B result 0 1 0 0 0 0 0 0 4. PD (Pulse Duration) set to 8 ms RegisterWrite(0x1C,10) $1C PW PD[7] PD [6] PD [5] PD [4] PD [3] PD [2] PD [1] PD [0] $1C result 0 0 0 1 0 0 0 0 AN3468 Sensors Freescale Semiconductor 23 Optimal Settings for Double Pulse Detection • • • • • • Positive OR Logic PDPL = 0 Z-axis enabled only Pulse Threshold set to 4 g Pulse Duration = $3C (60 counts) 30 ms Latency Time = 0x5A 90 ms 2nd Time Window 0x82 (130 ms) 1. Positive OR Logic Enabled PDPL = 0 RegisterWrite(0x19,regs[0x19]&0xFD) $19 CTL2 — — — — — DRVO PDPL LDPL $19 mask 1 1 1 1 1 1 0 1 $19 result — — — — — DRVO 0 LDPL 2. Z only enabled RegisterWrite(0x18,(regs[0x18]&0x98)|0x18) $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $18 mask 1 0 0 1 1 0 0 0 $18 result DFBW 0 0 1 1 INTRG[1] INTRG[0] INTPIN 3. PDTH (Pulse Threshold) set to 4 g RegisterWrite(0x1B,0x40) $1B PDTH PDTH[7] PDTH[6] PDTH[5] PDTH[4] PDTH[3] PDTH[2] PDTH[1] PDTH[0] $1B result 0 1 0 0 0 0 0 0 4. Pulse Duration for first pulse 30 ms RegisterWrite(0x1C,0x3C) $1C PW PD[7] PD [6] PD [5] PD [4] PD [3] PD [2] PD [1] PD [0] $1C result 0 0 1 1 1 1 0 0 5. Latency time between the pulses 90 ms RegisterWrite(0x1D,0x5A) $1D LT LT[7] LT [6] LT [5] LT [4] LT [3] LT [2] LT [1] LT [0] $1D result 0 1 0 1 1 0 1 0 6. Time Window for Second Pulse = 130 ms RegisterWrite(0x1E,0x82) $1E TW TW[7] TW [6] TW [5] TW [4] TW [3] TW [2] TW [1] TW [0] $1E result 1 0 0 0 0 0 1 0 AN3468 Sensors Freescale Semiconductor 24 Table 2. User Registers Summary Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 $00 XOUTL XOUT[7] XOUT[6] XOUT[5] XOUT[4] XOUT[3] XOUT[2] XOUT[1] XOUT[0] $01 XOUTH — — — — — — XOUT[9] XOUT[8] $02 YOUTL YOUT[7] YOUT[6] YOUT[5] YOUT[4] YOUT[3] YOUT[2] YOUT[1] YOUT[0] $03 YOUTH — — — — — — YOUT[9] YOUT[8] $04 ZOUTL ZOUT[7] ZOUT[6] ZOUT[5] ZOUT[4] ZOUT[3] ZOUT[2] ZOUT[1] ZOUT[0] $05 ZOUTH — — — — — — ZOUT[9] ZOUT[8] $06 XOUT8 XOUT[7] XOUT[6] XOUT[5] XOUT[4] XOUT[3] XOUT[2] XOUT[1] XOUT[0] $07 YOUT8 YOUT[7] YOUT[6] YOUT[5] YOUT[4] YOUT[3] YOUT[2] YOUT[1] YOUT[0] $08 ZOUT8 ZOUT[7] ZOUT[6] ZOUT[5] ZOUT[4] ZOUT[3] ZOUT[2] ZOUT[1] ZOUT[0] $09 STATUS — — — — — PERR DOVR DRDY $0A DETSRC LDX LDY LDZ PDX PDY PDZ INT2 INT1 $0B TOUT TMP[7] TMP[6] TMP[5] TMP[4] TMP[3] TMP[2] TMP[1] TMP[0] $0C — — — — — — — — — $0D I2CAD I2CDIS DAD[6] DAD[5] DAD[4] DAD[3] DAD[2] DAD[1] DAD[0] $0E USRINF UI[7] UI[6] UI[5] UI[4] UI[3] UI[2] UI[1] UI[0] $0F WHOAM ID[7] ID[6] ID[5] ID[4] ID[3] ID[2] ID[1] ID[0] $10 XOFFL XOFF[7] XOFF[6] XOFF[5] XOFF[4] XOFF[3] XOFF[2] XOFF[1] XOFF[0] $11 XOFFH — — — — — XOFF[10] XOFF[9] XOFF[8] $12 YOFFL YOFF[7] YOFF[6] YOFF[5] YOFF[4] YOFF[3] YOFF[2] YOFF[1] YOFF[0] $13 YOFFH — — — — — YOFF[10] YOFF[9] YOFF[8] $14 ZOFFL ZOFF[7] ZOFF[6] ZOFF[5] ZOFF[4] ZOFF[3] ZOFF[2] ZOFF[1] ZOFF[0] $15 ZOFFH — — — — — ZOFF[10] ZOFF[9] ZOFF[8] $16 MCTL LPEN DRPD SPI3W STON GLVL[1] GLVL[0] MOD[[1]] MOD[0] $17 INTRST — — — — — — CLRINT2 CLRINT1 $18 CTL1 DFBW THOPT ZDA YDA XDA INTRG[1] INTRG[0] INTPIN $19 CTL2 — — — — — DRVO PDPL LDPL $1A LDTH LDTH[7] LDTH[6] LDTH[5] LDTH[4] LDTH[3] LDTH[2] LDTH[1] LDTH[0] $1B PDTH PDTH[7] PDTH[6] PDTH[5] PDTH[4] PDTH[3] PDTH[2] PDTH[1] PDTH[0] $1C PW PD[7] PD [6] PD [5] PD [4] PD [3] PD [2] PD [1] PD [0] $1D LT LT[7] LT [6] LT [5] LT [4] LT [3] LT [2] LT [1] LT [0] $1E TW TW[7] TW [6] TW [5] TW [4] TW [3] TW [2] TW [1] TW [0] $1F — — — — — — — — — NOTES: 1. http://www.esacademy.com/faq/i2c/general/i2cpseud.htm AN3468 Sensors Freescale Semiconductor 25 How to Reach Us: Home Page: www.freescale.com Web Support: http://www.freescale.com/support USA/Europe or Locations Not Listed: Freescale Semiconductor, Inc. Technical Information Center, EL516 2100 East Elliot Road Tempe, Arizona 85284 1-800-521-6274 or +1-480-768-2130 www.freescale.com/support Europe, Middle East, and Africa: Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) www.freescale.com/support Japan: Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 [email protected] Asia/Pacific: Freescale Semiconductor China Ltd. Exchange Building 23F No. 118 Jianguo Road Chaoyang District Beijing 100022 China +86 010 5879 8000 [email protected] For Literature Requests Only: Freescale Semiconductor Literature Distribution Center 1-800-441-2447 or +1-303-675-2140 Fax: +1-303-675-2150 [email protected] AN3468 Rev. 1 05/2009 Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. “Typical” parameters that may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including “Typicals”, must be validated for each customer application by customer’s technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part. Freescale™ and the Freescale logo are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners. © Freescale Semiconductor, Inc. 2009. All rights reserved.