## **AN12386** # **SPI Communication Procedure Recommendations for the FXLS9xxxx** Rev. 1.2 — 8 January 2021 **Application note** ## 1 Introduction The purpose of this document is to describe the SPI power up, initialization and normal mode procedures for the FXLS9xxxx single and dual channel inertial sensors. ## 2 Applicable Parts This document applies to the following NXP sensors: #### Table 1. Applicable parts | FXLS9xxxx | uThornapple | Dual Channel SPI Inertial Sensor | | | | | |-----------|-------------|------------------------------------|--|--|--|--| | FXLS9xxxx | uLaurel | Single Channel SPI Inertial Sensor | | | | | ## 3 Definition List #### Table 2. Definition list | Term | Definition | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Analog Self-Test | A method to test the acceleration signal chain by electrostatically deflecting the transducer proof mass and measuring the device output. | | Digital Self-Test | A method to test the digital portion of the acceleration signal chain by forcing a value or a sequence of values at the output of the analog to digital converter and measuring the device output. | | DSP | Digital Signal Processing Block | | MOSI | Master Output, Slave Input. The MOSI signal is output from the master to all slaves on the bus. | | MISO | Master Input, Slave Output. The MISO signal is output from one slave to the master. | | POR | Power On Reset | | SCLK | Serial Clock. The SCLK signal is output from the master to all the slaves on the bus. | | SS_B | Slave Select Bar. The SS_B signal is an active low signal output from the master to each slave independently on the bus. | | SPI | Serial Peripheral Interface, a full duplex, synchronous serial interface. The FXLS9xxxx and FXLSAxxxx devices operate using a 4-wire SPI. | ## 4 Further Assistance For further assistance please contact a local NXP sales representative. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 5 References - FXLS9xxxx data sheet, latest revision: uThornapple data sheet - FXLS9xxxx data sheet, latest revision: uLaurel data sheet ## 6 Revision History Table 3. Revision history | Rev. No. | Date | Description | |----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0.1 | 20141028 | Initial Release | | 0.2 | 20150118 | <ul><li>Updated based on customer feedback.</li><li>Added Flowcharts for each procedure.</li></ul> | | 0.3 | 20150608 | <ul> <li>Updated the startup sequence and overall flow.</li> <li>Updated the soft reset sequence and the status verification sequence.</li> <li>Updated the self-test flows.</li> <li>Added expected responses for all section up to the self-test configuration section.</li> </ul> | | 0.4 | 20150714 | <ul> <li>Added expected responses for all sections.</li> <li>Added the 3-Bit and 4-Bit CRCs for each command.</li> <li>Clarified all self-test procedures.</li> <li>Added the self-test accuracy test procedure.</li> <li>Added the continuous oscillator verification procedure.</li> <li>Added offset and self-test limit calculations and examples.</li> <li>Added all delay time references for offset and self-test procedures.</li> <li>Added reference from Overview Flowcharts to Detailed Flowcharts.</li> <li>Added an example Self-Test Output.</li> </ul> | | 0.5 | 20150714 | Updates and corrections after internal review. | | 1.0 | 20190313 | Initial revision. Created from AN5358 | | 1.1 | 20190517 | Analog Self-test sequence modified for uTA 3.1. | | 1.2 | 20210108 | Updated Analog Self-Test sequence for uTA 3.2/ uLA 2.1 | SPI Communication Procedure Recommendations for the FXLS9xxxx ## 7 Apply Power to the FXLS9xxxx Power must be applied to the FXLS9xxxx with the ramp rates specified in the data sheet. The device is verified to properly startup with ramp rates from 10 V/s to 10 V/µs. The device is specified to work with either a 3.3 V supply or a 5 V supply. ## 8 Initialize and Configure the Devices The following sections describe the recommended SPI commands to initialize, configure and test an FXLS9xxxx (uThornapple) device. <u>Figure 2</u> shows an example timing diagram for SPI Start Up and initialization and how it compares to the internal offset cancellation start up. <u>Figure 3</u> shows a high level flow chart of the SPI sequence. Note: CRC computation provided in this document are using the below configuration: AN12386 All information provided in this document is subject to legal disclaimers. © NXP B.V. 2021. All rights reserved. ## SPI Communication Procedure Recommendations for the FXLS9xxxx #### Table 4. 8-bit CRC | Method | Value | |------------------|-----------| | Polynomial | 100101111 | | Non Direct Seeds | 11111111 | #### Table 5. 4-bit CRC | Method | Value | | | |------------------|-------|--|--| | Polynomial | 10001 | | | | Non Direct Seeds | 1010 | | | #### Table 6. 3-bit CRC | Method | Value | |------------------|-------| | Polynomial | 1011 | | Non Direct Seeds | 111 | #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.1 Complete a soft reset The first step is to complete a soft reset of the device to ensure consistent power up operation. This is accomplished by sending three consecutive write commands to the DEVLOCK\_WR register of each device. The proper sequence is shown in <u>Section 8.1</u>. #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 8.2 Confirm device status The next step is to confirm proper SPI communication and the expected status of the device by following the procedure shown in <u>Figure 5</u>. The DEVSTAT register mapping is shown in <u>Figure 6</u>. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.3 Configure SPI communication The next step is to optionally configure the SPI communication for the desired sensor data field size and the desired error detection method including CRC length, CRC seed and Message Counter. This step is not necessary if the default SPI communication settings will be used: 8-bit CRC and 12-bit Sensor Data. The flowchart in <a href="Figure 7">Figure 7</a> shows some of the typical SPI configurations. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.4 Optional complete register pattern write verification The next step is to complete a register pattern write verification. This step is optional and not required to meet the diagnostic coverage as documented in the FMEDA. The recommended procedure for register pattern write verification is shown in <u>Figure 8</u>. In this example, the WHOAMI and I2C\_ADDRESS registers are used for pattern writing as they are unused for the SPI application. Other registers can be used as long as the function for the register being written to is considered. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.5 Configure the data sources The next step is to configure the devices for the desired data sources and source identifiers. Figure 9 shows one example configuration. Each channel of the FXLS9xxxx devices has the capability for two independently configurable data sources. Figure 10 shows a pictorial mapping of the sources to their Source Identifiers and associated data. #### SPI Communication Procedure Recommendations for the FXLS9xxxx The sources are enabled and the associated Source Identifiers are set using the registers listed in the $\underline{\mathsf{Table}\ \mathsf{7}}$ . Table 7. Source Identifier registers | Register<br>Address | Register Name | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |---------------------|---------------|-----------------------------------------------------------|----------|---------------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----| | \$1A | SOURCEID_0 | SID0_EN<br>Enable<br>Channel 0<br>Source 0,<br>Datatype 0 | | M_FORMA <sup>-</sup><br>licable for S | | <ul> <li>SOURCEID_0[3:0]</li> <li>System level source identifier for Channel 0, Datatype 0</li> <li>Notes:</li> <li>Each source identifier value for the device must be unique or the device will transmit error messages for the repeated identifier.</li> <li>For SPI mode, valid source ids are 0x0 to 0x7. No SPI sensor data requests are implemented for 0x8 to 0xF.</li> </ul> | | | | | \$1B | SOURCEID_1 | SID1_EN<br>Enable<br>Channel 0<br>Source 1,<br>Datatype 1 | Reserved | Reserved | Reserved | SOURCEID_1[3:0] System level source identifier for Channel Datatype 1 Notes: • Each source identifier value for the devic must be unique or the device will transmerror messages for the repeated identifier • For SPI mode, valid source ids are 0x0 to 0x7. No SPI sensor data requests are implemented for 0x8 to 0xF. | | | | | Register<br>Address | Register Name | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |---------------------|---------------|-----------------------------------------------------------|----------|----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----| | \$1C | SOURCEID_2 | SID2_EN<br>Enable<br>Channel 1<br>Source 2,<br>Datatype 0 | Reserved | Reserved | Reserved | SOURCEID_2[3:0] System level source identifier for Channel 1, Datatype 0 Notes: • Each source identifier value for the device must be unique or the device will transmit error messages for the repeated identifier. • For SPI mode, valid source ids are 0x0 to 0x7. No SPI sensor data requests are implemented for 0x8 to 0xF. | | | | | \$1D | SOURCEID_3 | SID3_EN<br>Enable<br>Channel 1<br>Source 3,<br>Datatype 1 | Reserved | Reserved | Reserved | SOURCEID_3[3:0] System level source identifier for Channel 1 Datatype 1 Notes: • Each source identifier value for the device must be unique or the device will transmit error messages for the repeated identifier • For SPI mode, valid source ids are 0x0 to 0x7. No SPI sensor data requests are implemented for 0x8 to 0xF. | | | | #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.6 Configure the sensor signal chain The next step is to configure the sensor signal chain. Figure 11 shows an example configuration. The delay times included are specific to the configuration selected and must be adjusted if alternative filters are selected. The self-test verification calculations are also specific to the configuration selected and must be adjusted if alternative gains are used. #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 8.6.1 Signal chain low pass filter selection The signal chain low pass filter is selected by a combination of the LPF bits and the SAMPLERATE bits in the CHx\_CFG\_U1 register as shown in the datasheet. The LPF selection table is shown below. Table 8. Signal chain low pass filter selection | | | - | Low Pass Filter Type | | | | | | |--------|--------|--------|----------------------|--------------------------------|------------------|------------------|--|--| | LPF[3] | LPF[2] | LPF[1] | LPF[0] | SAMPLERATE = 00, 01 | SAMPLERATE = 10 | SAMPLERATE = 11 | | | | | | | | 16 µs | 32 µs | 64 µs | | | | 0 | 0 | 0 | 0 | 400 Hz, 4-Pole | 200 Hz, 4-Pole | 100 Hz, 4-Pole | | | | 0 | 0 | 0 | 0 | 400 Hz, 3-Pole | 200 Hz, 3-Pole | 100 Hz, 3-Pole | | | | 0 | 0 | 1 | 0 | 400 Hz, 4-Pole | 200 Hz, 4-Pole | 100 Hz, 4-Pole | | | | 0 | 0 | 1 | 1 | 400 Hz, 3-Pole | 200 Hz, 3-Pole | 100 Hz, 3-Pole | | | | 0 | 1 | 0 | 0 | 325 Hz, 3-Pole | 162.5 Hz, 3-Pole | 81.25 Hz, 3-Pole | | | | 0 | 1 | 0 | 1 | 370 Hz, 2-Pole | 185 Hz, 2-Pole | 92.5 Hz, 2-Pole | | | | 0 | 1 | 1 | 0 | 180 Hz, 2-Pole | 90 Hz, 2-Pole | 45 Hz, 2-Pole | | | | 0 | 1 | 1 | 1 | 100 Hz, 2-Pole | 50 Hz, 2-Pole | 25 Hz, 2-Pole | | | | 1 | 0 | 0 | 0 | 1500 Hz, 4-Pole 750 Hz, 4-Pole | | 375 Hz, 4-Pole | | | | 1 | 0 | 0 | 1 | 500 Hz, 3-Pole | 250 Hz, 3-Pole | 125 Hz, 3-Pole | | | | 1 | 0 | 1 | 0 | 800 Hz, 4-Pole | 400 Hz, 4-Pole | 200 Hz, 4-Pole | | | | 1 | 0 | 1 | 1 | 1200 Hz, 4-Pole | 600 Hz, 4-Pole | 300 Hz, 4-Pole | | | | 1 | 1 | 0 | 0 | 120 Hz, 3-Pole | 60 Hz, 3-Pole | 30 Hz, 3-Pole | | | | 1 | 1 | 0 | 1 | 20 kHz, 2-Pole | 10 kHz, 2-Pole | 5 kHz, 2-Pole | | | | 1 | 1 | 1 | 0 | 120 Hz, 2-Pole | 60 Hz, 2-Pole | 30 Hz, 2-Pole | | | | 1 | 1 | 1 | 1 | 50 Hz, 4-Pole | 25 Hz, 4-Pole | 12.5 Hz, 4-Pole | | | #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 8.6.2 Signal chain user gain selection The signal chain user gain is selected by a combination of the U\_SNS\_SHIFT bits in the CHx\_CFG\_U1 register and the U\_SNS\_MULT bits in the CHx\_CFG\_U2 register. The equation and some example user range and sensitivities are included in the datasheet. The process and equations for determining the U\_SNS\_SHIFT and U\_SNS\_MULT settings from desired range and sensitivity values is also listed below along with a medium g example. - 1. Determine the overall sensitivity adjustment factor: - Desired Typical User Range = ±100 g with 12-bit data - · Calculate Desired Sensitivity $$Sense_{Typical\ Desired} = \frac{2^{11}-1}{Range_{Typical\ Desired}} = \frac{2047}{100} = 20.47\ LSB g$$ 2. Calculate the required sensitivity adjustment for a medium g device $$SENSE_{Adjust\ Total} = \frac{Sense_{Typical\ Desired}}{Sense_{Typical\ NXP\ Trim}} = \frac{20.47}{33.0161} = 0.6200$$ 3. Determine the best U\_SNS\_SHIFT setting: Table 9. Signal chain user gain selection | Sense <sub>AdjustTotal</sub> | U_SNS_SHIFT Gain | U_SNS_SHIFT Setting | |--------------------------------------------|------------------|---------------------| | Sense <sub>AdjustTotal</sub> < 0.25 | Invalid Range | Invalid Range | | $0.25 \le Sense_{AdjustTotal} < 0.50$ | 0.25 | 00 | | 0.50 ≤ Sense <sub>AdjustTotal</sub> < 1.00 | 0.50 | 01 | | 1.00 ≤ Sense <sub>AdjustTotal</sub> < 2.00 | 1.00 | 10 | | $2.00 \le Sense_{AdjustTotal} < 4.00$ | 2.00 | 11 | | 4.00 ≤ Sense <sub>AdjustTotal</sub> | Invalid Range | Invalid Range | 4. Determine the U\_SNS\_MULT setting: $$U \ SNS \ MULT = ROUND \left[ \left( \frac{Sense_{Typical \ Desired}}{Sense_{Typical \ NXP \ Trim}^*U \ SNS \ SHIFT} - 1 \right)^* 256 \right] = \left( \frac{0.62}{0.50} - 1 \right)^* 256 = 61 decimal$$ $$U \ SNS \ MULT = 0x3D$$ #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.6.3 Signal chain data type configuration Each source enabled (as described in <u>Section 8.5</u>) must have its data type configured. Datatype configuration is described in the datasheet. A simplified table is included below: Table 10. Datatype configuration | CHx DATATYPEx[1:0] | | Sensor data description | | | | |--------------------|---|---------------------------------------------------------|--|--|--| | 0 | 0 | Offset Cancelled Data as Configured by the OC_FILT bits | | | | | 0 | 1 | Raw Data (No Offset Cancellation) | | | | | 1 | 0 | Temperature Sensor Data | | | | | 1 | 1 | Temperature Sensor Data | | | | #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.7 Complete startup coarse oscillator verification The next step is to complete a coarse verification of the device oscillator. This is accomplished by reading the COUNT register and comparing the values over specific periods of time. At a minimum, the startup coarse oscillator verification is required to meet the diagnostic coverage as documented in the FMEDA. The recommended procedure for coarse oscillator verification is shown in <u>Figure 12</u>. The procedure described includes a delay of 6 ms. A 6 ms delay can detect an oscillator error of greater ±10% with a master oscillator of less than ±1%. Reference section <u>Section 9</u> "<u>Optional Continuous Oscillator Verification</u>" for details on the oscillator verification detection capability and the recommended limits for different measurement times and master oscillator accuracy cases. #### 8.8 Confirm traceability information The next step is to confirm the device level traceability information. The IC type, IC manufacturer ID, IC Part Number and IC Serial Number should be read to confirm that the proper device is connected. This can be accomplished on each power up as documented here, or one time only during the system manufacturing. The additional traceability information should also be read and stored in memory, or accessible via other means with a diagnostic tool to assist in failure analysis of quality incidents. The additional traceability information is not required to meet the functional safety requirements of safety systems. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.9 Optional read and record stored self-test data The next step is to read and record the self-test data stored in the device during device manufacturing. Reading this data is only necessary if the optional self-test accuracy verification test is used, as described in <a href="Section 8.11.4.1.3" Optional self-test accuracy verification"</a>. The optional self-test accuracy verification test can be run at each power up as documented here, or one time only during system manufacturing. Reference <a href="Section 8.10" Confirm the device configuration">Section 8.10</a> "Confirm the device configuration" and the associated sub-sections for details on how to use the stored self-test data for additional self-test accuracy. Figure 14 shows the procedure for reading the stored self-test data. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.10 Confirm the device configuration The next step is to confirm the device configuration. All registers that impact the communication or signal chain configuration should be read whether they were written by the user or not. This provides an additional verification of the reset state of all registers beyond the internal OTP CRC. Figure 15 shows an example configuration. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.11 Complete self-test (self-test overview) The next step is to complete some or all of the various self-test functions available in the device. Figure 17 shows an overview of a recommended procedure for completing self-test. Test repeats on failure are not shown in the diagrams. The user must determine the number of test repeats for each test type based on the application. Typically test repeats are kept at a minimum for the analog self-test procedures in order to avoid the type of invalid inputs that are common during startup. #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 8.11.1 Complete pre-self-test offset The next step is to complete an offset verification. The purpose of the offset verification is to: - 1. Verify the offset of the device and any change in offset before and after the self-test motion. - 2. Capture the pre-self-test offset that will be subtracted from the measured self-test values during analog self-test. The flow charts below show an example procedure for capturing the sensor offset. #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 8.11.2 Complete fixed value self-test The next step is to complete a fixed value self-test verification for each device. The purpose of the fixed value self-test is to confirm that the output data register and communication block have no stuck bit conditions. Figure 18 shows an example procedure for completing self-test with two fixed values. The example alternates 0x5555 and 0xAAAA by channel to confirm both states of each bit in the data field and to maximize verification of channel independent data. Expected responses are included for each self-test request. #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 8.11.3 Complete digital self-test The next step is to complete a digital self-test verification for each device. The purpose of the digital self-test is to achieve a more accurate verification of the digital signal chain. The digital self-test forces a known value into the input of the digital signal chain. After a defined interval of time, dependent on the low pass filter selected, the signal chain output can be verified against an expected value plus or minus a small tolerance. Figure 19 #### SPI Communication Procedure Recommendations for the FXLS9xxxx shows an example procedure for completing a self-test of one digital value (Digital Self-Test 0xC) and confirming the expected output value. If offset cancellation is being used, bypass the offset cancellation filter for digital selftest to eliminate the effects of the filter on the digital self-test result. The procedure below includes offset cancellation bypass during digital self-test. #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 8.11.3.1 Digital self-test limit calculation The digital self-test provides a constant value to the sensor data output regardless of the user gain settings. The limits for the minimum gain setting are listed in the datasheet and included in Table 11 below. Table 11. Data sheet digital self-test values with minimum gain | Self-test<br>ST_CTRL[3:0] | Expected value CHx_SNSDATAx register read (signed HEX) Min Typ Max | | Expected value CHx_SNSDATAx register read (unsigned HEX) | | | Expected value CHx_SNSDATAx register read (decimal) | | | | |---------------------------|---------------------------------------------------------------------|------|----------------------------------------------------------|------|------|-----------------------------------------------------|-------|-------|-------| | | | | Max | Min | Тур | Max | Min | Тур | Max | | 0xC | E77F | E780 | E781 | 677F | 6780 | 6781 | -6273 | -6272 | -6271 | | 0xD | 0FA3 | 0FA4 | 0FA5 | 8FA3 | 8FA4 | 8FA5 | 4003 | 4004 | 4005 | | 0xE | EFA2 | EFA3 | EFA4 | 6FA2 | 6FA3 | 6FA4 | -4190 | -4189 | -4188 | | 0xF | 07B7 | 07B8 | 07B9 | 87B7 | 87B8 | 87B9 | 1975 | 1976 | 1977 | #### 8.11.4 Complete analog self-test The next step is to complete an offset and analog self-test verification. The purpose of the analog self-test is to: - Confirm unimpeded motion of the proof mass in both the positive and negative acceleration directions. - 2. Verify the sensitivity accuracy of the device. The FXLS9xxxx devices contain multiple self-test capabilities and procedures that have different sensitivity accuracy verification capabilities. - 3. Verify the offset of the device and any change in offset before and after the self-test motion. The flow charts below show an example analog self-test procedure for measuring both positive and negative self-test. <u>Section 8.11.4.1 "Analog self-test pass fail limits"</u> explains the pass/fail criteria for analog self-test. When sensor data is read for any of the analog self-test functions, the sensor data can be accessed either by using the Sensor Data Request commands or by reading the SNSDATA registers directly. For some user gain settings, the analog self-test results in a potential railed sensor data output via the Sensor Data Request commands. For these test cases, the data must be read via the SNSDATA registers. Note that if the SNSDATA registers are read directly, the arming function is not updated and arming pin verification is not feasible. If the arming function is to be verified, either a separate self-test arming verification test can be run or both the Sensor Data Request command and the SNSDATA registers reads can be completed simultaneously. #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 8.11.4.1 Analog self-test pass fail limits The analog self-test results can be evaluated via several methods. This section covers the various methods for evaluating the offset and self-test results to improve diagnostic coverage. The tests described in <u>Section 8.11.4.1.1 "Standard offset verification"</u> and AN12386 All information provided in this document is subject to legal disclaimers. © NXP B.V. 2021. All rights reserved. #### SPI Communication Procedure Recommendations for the FXLS9xxxx <u>Section 8.11.4.1.2 "Standard self-test verification"</u> are required to meet the diagnostic coverage as documented in the FMEDA. The additional tests improve diagnostic coverage. #### 8.11.4.1.1 Standard offset verification The average offset calculated from each data source captured from the test in <u>Figure 17</u> is compared against the offset limits in the datasheet. If offset cancellation (high pass filter) is not used and a lower range is programmed than the range condition specified for offset (25 g for medium g, 100 g for high g), the offset limits must be scaled with the user gain. Table 12 shows some example offset test limits for different ranges and settings. Offset verification in this procedure is included as part of the initialization procedure. If it is more convenient for the user, offset verification can be completed after entering Normal Mode. Table 12. Standard offset verification test limits, medium g | Offset cancellation enabled? | User programmed range medium g (g) | Minimum limit<br>(LSB, 12-bit) | Maximum limit<br>(LSB, 12-bit) | Pass / fail criteria | |------------------------------|------------------------------------|--------------------------------|--------------------------------|----------------------| | Yes | All | -1 | +1 | | | No | 15.5 | -162 | +162 | | | No | 16.0 | -157 | +157 | | | No | 20.0 | -126 | +126 | | | No | 25.0 | -100 | +100 | | | No | 35.0 | -72 | +72 | | | No | 50.0 | -50 | +50 | | | No | 60.0 | -42 | +42 | | | No | 62.0 | -41 | +41 | Min Limit | | No | 62.5 | -41 | +41 | | | No | 75.0 | -34 | +34 | | | No | 85.3 | -30 | +30 | | | No | 100.0 | -25 | +25 | | | No | 105.0 | -24 | +24 | | | No | 112.5 | -23 | +23 | | | No | 125.0 | -21 | +21 | | | No | 128.0 | -20 | +20 | | | No | 150.0 | -17 | +17 | | #### SPI Communication Procedure Recommendations for the FXLS9xxxx Table 13. Standard offset verification test limits, high g | Offset cancellation enabled? | User programmed range<br>high g (g) | Minimum limit<br>(LSB, 12-bit) | Maximum limit<br>(LSB, 12-bit) | Pass / fail criteria | |------------------------------|-------------------------------------|--------------------------------|--------------------------------|----------------------| | Yes | All | -1 | +1 | | | No | 50.0 | -200 | +200 | | | No | 60.0 | -167 | +167 | | | No | 62.0 | -162 | +162 | | | No | 62.5 | -160 | +160 | | | No | 100.0 | -100 | +100 | | | No | 105.0 | -96 | +96 | | | No | 112.5 | -89 | +89 | Min Limit | | No | 125.0 | -80 | +80 | ≤ Result ≤ | | No | 128.0 | -79 | +79 | Max Limit | | No | 150.0 | -67 | +67 | | | No | 187.0 | -54 | +54 | | | No | 250.0 | -40 | +40 | | | No | 312.5 | -32 | +32 | | | No | 375.0 | -27 | +27 | | | No | 500.0 | -20 | +20 | | | No | 748.0 | -14 | +14 | | The table below summarizes the post-self-test offset values measured in the example run for this application note. Table 14. Offset measured values | Channel | User<br>programmed<br>range<br>medium g<br>(g) | Offset cancellation? | Minimum limit<br>(LSB, 12-bit) | 20ms average<br>post-self-<br>test offset<br>(LSB, 12-bit) | Maximum limit<br>(LSB, 12-bit) | Pass /<br>fail | |---------|------------------------------------------------|----------------------|--------------------------------|------------------------------------------------------------|--------------------------------|----------------| | 0 | 150g | No | -100 | 0.25 | +100 | Pass | | 0 | 150g | Yes | -1 | 0.51 | +1 | Pass | | 1 | 15.5g | No | -167 | 7.20 | +167 | Pass | | 1 | 15.5g | Yes | -1 | 0.57 | +1 | Pass | #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 8.11.4.1.2 Standard self-test verification The resulting positive and negative self-test values from the tests in Figure 22 through Figure 25 are compared against the self-test limits in the datasheet. The self-test limits must be scaled with the user gain. The equation used to convert the specified self-test in g to minimum and maximum self-test limits is shown below. Table 15 through Table 18 show some example self-test limits for different ranges and settings. $$AnalogSelfTest_{Min@UserGain} = Truncate[ST_{MH\_62X\_13min}*(UserGain)]$$ $$AnalogSelfTest_{Max@UserGain} = RoundUp[ST_{MH\_62X\_13max}*(UserGain)]$$ #### Where: - AnalogSelfTest<sub>Min@UserGain</sub> = The SNSDATAx register analog self-test minimum limit for the configured user gain - AnalogSelfTest<sub>Max@UserGain</sub> = The SNSDATAx register analog self-test maximum limit for the configured user gain - $ST_{MH\_62X\_13min}$ = The min med g SNSDATAx register self-test delta from offset for a user gain of 1 - ST<sub>MH\_62X\_13max</sub> = The max med g SNSDATAx register self-test delta from offset for a user gain of 1 - *UserGain* = The configured gain, calculated as shown in <u>Section 8.6.2 "Signal chain</u> user gain selection" Table 15. Standard self-test verification test limits, medium g X-axis | Device | NXP trim value | User<br>programmed | User<br>programmed | | ATA register value <sup>[1]</sup> )<br>SB) | Pass / fail | | | | |---------------|----------------|----------------------------|--------------------|------|--------------------------------------------|-------------|--|--|--| | type | (LSB/g) | range gain Minimum Maximum | | | | | | | | | | | 15.5 | 3.9922 | 7038 | 16428 | | | | | | | | 16.0 | 3.8750 | 6831 | 15946 | | | | | | | | 20.0 | 3.1016 | 5468 | 12763 | | | | | | | | 25.0 | 2.4766 | 4366 | 10192 | | | | | | | | 35.0 | 1.7695 | 3119 | 7282 | | | | | | | | 50.0 | 1.2383 | 2183 | 5096 | | | | | | | | 60.0 | 1.0352 | 1824 | 4260 | | | | | | | | 62.0 | 1.0000 | 1763 | 4115 | | | | | | | | 62.5 | 0.9922 | 1749 | 4083 | Min Limit | | | | | Medium<br>g X | 33.0161 | 64.0 | 0.9688 | 1707 | 3987 | ≤ Result ≤ | | | | | 9 | | 75.0 | 0.8262 | 1456 | 3400 | Max Limit | | | | | | | 85.3 | 0.7266 | 1280 | 2990 | | | | | | | | 100.0 | 0.6191 | 1091 | 2548 | | | | | | | | 105.0 | 0.5898 | 1039 | 2428 | | | | | | | | 112.5 | 0.5508 | 971 | 2267 | | | | | | | | 125.0 | 0.4961 | 874 | 2042 | 1 | | | | | | | 128.0 | 0.4844 | 853 | 1994 | | | | | | | | 150.0 | 0.4131 | 728 | 1700 | | | | | | | | 248.0 | 0.2500 | 440 | 1029 | | | | | <sup>[1]</sup> If the self-test limits exceed 2<sup>11</sup>-1 (2047) LSB, self-test value must be read using reads of the SNSDATA register to avoid railed value. Table 16. Standard self-test verification test limits, medium g Z-axis | Device | NXP trim value | User programmed | User<br>programmed | Self-test limits, SNSD<br>(LS | | Pass / fail | | | | |---------------|----------------|----------------------------|--------------------|-------------------------------|------|-------------|--|--|--| | type | (LSB/g) | range gain Minimum Maximum | | | | | | | | | | | 15.5 | 3.9922 | 3421 | 7993 | | | | | | | | 16.0 | 3.8750 | 3320 | 7758 | | | | | | | | 20.0 | 3.1016 | 2658 | 6210 | | | | | | | | 25.0 | 2.4766 | 2122 | 4959 | | | | | | | | 35.0 | 1.7695 | 1516 | 3543 | | | | | | | | 50.0 | 1.2383 | 1061 | 2480 | | | | | | | | 60.0 | 1.0352 | 887 | 2073 | | | | | | | | 62.0 | 1.0000 | 857 | 2002 | | | | | | | | 62.5 | 0.9922 | 850 | 1987 | Min Limit | | | | | Medium<br>g Z | 33.0161 | 64.0 | 0.9688 | 830 | 1940 | ≤ Result ≤ | | | | | 3 | | 75.0 | 0.8262 | 708 | 1654 | Max Limit | | | | | | | 85.3 | 0.7266 | 622 | 1455 | | | | | | | | 100.0 | 0.6191 | 530 | 1240 | | | | | | | | 105.0 | 0.5898 | 505 | 1181 | | | | | | | | 112.5 | 0.5508 | 472 | 1103 | | | | | | | | 125.0 | 0.4961 | 425 | 994 | | | | | | | | 128.0 | 0.4844 | 415 | 970 | | | | | | | | 150.0 | 0.4131 | 354 | 827 | | | | | | | | 248.0 | 0.2500 | 214 | 501 | | | | | <sup>[1]</sup> If the self-test limits exceed 2<sup>11</sup>-1 (2047) LSB, self-test value must be read using reads of the SNSDATA register to avoid railed value. Table 17. Standard self-test verification test limits, high g X-axis | Device | NXP trim value | User programmed | User programmed | | ATA register value <sup>[1]</sup> )<br>SB) | Pass / fail criteria | | | | | | |----------|----------------|-----------------|-----------------|------|--------------------------------------------|----------------------|--|--|--|--|--| | type | (LSB/g) | range<br>(g) | gain | | | | | | | | | | | | 46.875 | 3.9922 | 2886 | 6743 | | | | | | | | | | 50 | 3.7422 | 2705 | 6321 | | | | | | | | | | 60 | 3.1172 | 2253 | 5265 | | | | | | | | | | 62 | 3.0156 | 2180 | 5094 | | | | | | | | | | 62.5 | 2.9922 | 2163 | 5054 | | | | | | | | | | 100 | 1.8711 | 1352 | 3161 | | | | | | | | | | 105 | 1.7813 | 1287 | 3009 | | | | | | | | | | 112.5 | 1.6641 | 1203 | 2811 | Min Limit | | | | | | | High g X | 10.9465 | 125 | 1.4961 | 1081 | 2527 | ≤ Result ≤ | | | | | | | | | 128 | 1.4609 | 1056 | 2468 | Max Limit | | | | | | | | | 150 | 1.2461 | 900 | 2105 | | | | | | | | | | 187 | 1.0000 | 723 | 1689 | | | | | | | | | | 250 | 0.7480 | 540 | 1264 | | | | | | | | | | 312.5 | 0.5977 | 432 | 1010 | | | | | | | | | | 375 | 0.4990 | 360 | 843 | | | | | | | | | | 500 | 0.3740 | 270 | 632 | | | | | | | | | | 748 | 0.2500 | 180 | 423 | - | | | | | | <sup>[1]</sup> If the self-test limits exceed 2<sup>11</sup>-1 (2047) LSB, self-test value must be read using reads of the SNSDATA register to avoid railed value. ### SPI Communication Procedure Recommendations for the FXLS9xxxx Table 18. Standard self-test verification test limits, high g Z-axis | Device | NXP trim value | User<br>programmed<br>range | User<br>programmed | Self-test limits, SNSD | Pass / fail criteria | | | | | | |----------|----------------|-----------------------------|--------------------|------------------------|----------------------|------------|--|--|--|--| | type | (LSB/g) | B/g) gain Minimum Maximum | | | | | | | | | | | | 46.875 | 3.9922 | 3329 | 7773 | | | | | | | | | 50 | 3.7422 | 3120 | 7287 | | | | | | | | | 60 | 3.1172 | 2599 | 6070 | | | | | | | | | 62 | 3.0156 | 2515 | 5872 | | | | | | | | | 62.5 | 2.9922 | 2495 | 5826 | | | | | | | | | 100 | 1.8711 | 1560 | 3644 | | | | | | | | | 105 | 1.7813 | 1485 | 3469 | | | | | | | | | 112.5 | 1.6641 | 1387 | 3240 | Min Limit | | | | | | High g Z | 10.9465 | 125 | 1.4961 | 1247 | 2913 | ≤ Result ≤ | | | | | | | | 128 | 1.4609 | 1218 | 2845 | Max Limit | | | | | | | | 150 | 1.2461 | 1039 | 2427 | | | | | | | | | 187 | 1.0000 | 834 | 1947 | | | | | | | | | 250 | 0.7480 | 623 | 1457 | | | | | | | | | 312.5 | 0.5977 | 498 | 1164 | | | | | | | | | 375 | 0.4990 | 416 | 972 | | | | | | | | | 500 | 0.3740 | 311 | 729 | | | | | | | | | 748 | 0.2500 | 208 | 487 | | | | | | <sup>[1]</sup> If the self-test limits exceed 2<sup>11</sup>-1 (2047) LSB, self-test value must be read using reads of the SNSDATA register to avoid railed value. ### 8.11.4.1.3 Optional self-test accuracy verification The resulting positive and negative self-test values from the tests in Figure 22 through Figure 25 can also be compared against the self-test values stored in the device OTP (see Section 8.9 "Optional read and record stored self-test data" ). This method provides a much tighter accuracy of the self-test limits. Independent positive and negative self-test values are stored for each channel. The stored values are equal to the absolute value of the difference between the self-test and offset values measured during the NXP factory trim/test at nominal temperature. Self-test stored values are captured with the user gain set to 1. Thus, the self-test limits must be calculated and then scaled with the user gain. The equation used to convert the stored self-test value to minimum and maximum self-test accuracy limits for the SNSDATA register values is shown below. Table 19 shows some example self-test accuracy limits for different ranges and settings. $$AnalogSelfTest_{AccMin@UserGain} = Truncate \left[ \textit{ST}_{Stored} *2*(1-\Delta STACC\_T)*(\textit{UserGain}) \right]$$ $$AnalogSelfTest_{AccMax@UserGain} = RoundUp[ST_{Stored}*2*(1+\Delta STACC\_T)*(UserGain)]$$ AN12386 All information provided in this document is subject to legal disclaimers. © NXP B.V. 2021. All rights reserved #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### Where: - AnalogSelfTest<sub>AccMin@UserGain</sub> = The SNSDATA register self-test accuracy min limit for the configured user gain - AnalogSelfTest<sub>AccMax@UserGain</sub> = The SNSDATA register self-test accuracy min limit for the configured user gain - ST<sub>Stored</sub> = The stored self-test value for the associated channel and self-test - $\Delta STACC_T$ = The self-test accuracy specified tolerance - *UserGain* = The configured gain, calculated as shown in Section <u>Section 8.6.2 "Signal chain user gain selection"</u> Table 19. Self-test accuracy verification example test limits | Device<br>type | User programmed range | User<br>programmed<br>gain | Example self-test stored value | SNSDATA re | curacy limits<br>egister value<br>LSB) | Pass / fail<br>criteria | |----------------|-----------------------|----------------------------|--------------------------------|------------|----------------------------------------|-------------------------| | | (g) | 9 | (LSB) | Minimum | Minimum | | | | 62 | 1 | 1000.00 | 1800 | 2200 | | | | 62 | 1 | 1470.00 | 2646 | 3234 | | | | 62 | 1 | 1800.00 | 3240 | 3960 | | | | 125 | 0.4961 | 1000.00 | 892 | 1092 | | | | 125 | 0.4961 | 1470.00 | 1312 | 1605 | | | Medium | 125 | 0.4961 | 1800.00 | 1607 | 1965 | Min Limit | | g X | 25 | 2.477 | 1000.00 | 4458 | 5450 | | | | 25 | 2.477 | 1470.00 | 6554 | 8011 | | | | 25 | 2.477 | 1800.00 | 8025 | 9809 | | | | 15 | 3.875 | 1000.00 | 6975 | 8525 | | | | 15 | 3.875 | 1470.00 | 10253 | 12532 | | | | 15 | 3.875 | 1800.00 | 12555 | 15345 | | <sup>[1]</sup> If the self-test limits exceed 2<sup>11</sup>-1 (2047) LSB, self-test value must be read using reads of the SNSDATA register to avoid railed value. #### 8.11.4.1.4 Optional self-test cross-coupling verification The self-test cross-coupling values can also be compared against the self-test cross-coupling output limits specified in the datasheet. The limits are independent of range so the cross-coupling values are directly compared against the specified limits: $\Delta$ STCh0\_1 and $\Delta$ STCh1\_0. #### 8.11.4.1.5 Optional post self-test delta offset verification The post self-test offset values can also be compared against the self-test delta offset limits specified in the datasheet. The limits are independent of range so the post self-test offset delta values are directly compared against the specified limits: $\Delta$ STOFF\_T. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 8.11.5 Restart offset cancellation fast startup Once Self-test is complete, if offset cancellation is enabled, the offset cancellation fast startup is reset to re-zero the offset cancellation. <u>Figure 26</u> shows the procedure for restarting the fast offset cancellation. #### 8.12 Transition to normal mode Once all self-test procedures are completed and verified, the system can transition the device from initialization to normal mode. This is done by setting the ENDINIT bit. <u>Figure 27</u> shows the command to set the ENDINIT bit and an example Normal Mode command sequence. - The command order for normal mode is chosen to provide status, Channel 0 data, and Channel 1 data. The device status is latched on the falling edge of the SS\_B for the response. This allows for the request to be transmitted during the previous loop. - Each sensor data response also includes status. Thus, the status can change from the beginning of the current loop to the end of the current loop. - Channel specific errors (CHx\_ERR bit set, offset errors, etc.) should always use the most recent status to determine the state of the data for that loop. - Device specific error status (memory errors, supply errors) are asynchronous and may change between channels. If a device specific error occurs at any time in the current loop, all sensor data for that loop should be considered to have the error status. #### SPI Communication Procedure Recommendations for the FXLS9xxxx # 9 Optional Continuous Oscillator Verification In addition to the coarse oscillator verification during initialization, the device oscillator can be continuously verified for accuracy via a continuous monitor of the COUNT register during normal mode. Figure 27 shows a recommended SPI command and response sequence for normal mode. The sequence includes a read of the DEVSTAT and COUNT register at a periodic rate. Figure 28, Figure 29 and Figure 30 below show the accuracy of the COUNT register oscillator verification method with different read repetition rates. Note that the COUNT register will roll over every 25.6 ms typically. Each of the examples below must account for the possibility of one counter rollover. A summary of the accuracy is shown in Table 20 Table 20. Oscillator verification accuracy summary | Count register read repetition rate (ms) | Master oscillator accuracy | Oscillator accuracy detection (%) | |------------------------------------------|----------------------------|-----------------------------------| | 1 | 0 ppm | 25 | | 1 | ± 100 ppm | 25 | | 1 | ± 1% | 25 | | 6 | 0 ppm | 10 | | 6 | ± 100 ppm | 10 | | 6 | ± 1% | 10 | | 24 | 0 ppm | 6 | | 24 | ± 100 ppm | 6 | | 24 | ± 1% | 10 | | | Case 8 | Case 7 | Case 6 | Case 5 | Case 4 | Case 3 | Case 2 | Case 1 | Case 0: | Case 1 | Case 2 | Case 3 | C 4 | Case 5 | Case 6 | Case 7 | Case 8 | |--------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|-------------------|----------|----------|----------|----------|----------|----------|----------|----------| | | Case 8 | Case 7 | Case 6 | | | | | | Normal | | | | Case 4 | | Case 6 | Case 7 | | | Oscillator Error | -50% | -25% | -15% | -10% | -6% | -5% | -2% | -1% | 0% | 1% | 2% | 5% | 6% | 10% | 15% | 25% | 50% | | Oscillator (Hz) | 5000000 | 7500000 | 8500000 | 9000000 | 9400000 | 9500000 | 9800000 | 9900000 | 10000000 | 10100000 | 10200000 | 10500000 | 10600000 | 11000000 | 11500000 | 12500000 | 15000000 | | COUNT Resolution (ms) | 0.2000 | 0.1333 | 0.1176 | 0.1111 | 0.1064 | 0.1053 | 0.1020 | 0.1010 | 0.1000 | 0.0990 | 0.0980 | 0.0952 | 0.0943 | 0.0909 | 0.0870 | 0.0800 | 0.0667 | | | | | | | | | | | | | | | | | | | | | Read Accuracy (perfect) | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | | Read Repetition Rate (ms) | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Min Expected COUNT Delta (LS8) | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | | Max Expected COUNT Delta (LSB) | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | | Min Actual COUNT Delta (LSB) | 5 | 7 | 8 | 9 | 9 | 9 | 9 | 9 | 10 | 10 | 10 | 10 | 10 | 11 | 11 | 12 | 15 | | Max Actual COUNT Delta (LSB) | 5 | 8 | 9 | 9 | 10 | 10 | 10 | 10 | 10 | 11 | 11 | 11 | 11 | 11 | 12 | 13 | 15 | | Pass/Fail | FAIL | FAIL | PASS FAIL | FAIL | | | | | | | | | | | | | | | | | | | | | | Case 8 | Case 7 | Case 6 | Case 5 | Case 4 | Case 3 | Case 2 | Case 1 | Case 0:<br>Normal | Case 1 | Case 2 | Case 3 | Case 4 | Case 5 | Case 6 | Case 7 | Case 8 | | Oscillator Error | -50% | -25% | -15% | -10% | -6% | -5% | -2% | -1% | 0% | 1% | 2% | 5% | 6% | 10% | 15% | 25% | 50% | | Oscillator (Hz) | 5000000 | 7500000 | 8500000 | 9000000 | 9400000 | 9500000 | 9800000 | 9900000 | 10000000 | 10100000 | 10200000 | 10500000 | 10600000 | 11000000 | 11500000 | 12500000 | 15000000 | | COUNT Resolution (ms) | 0.2000 | 0.1333 | 0.1176 | 0.1111 | 0.1064 | 0.1053 | 0.1020 | 0.1010 | 0.1000 | 0.0990 | 0.0980 | 0.0952 | 0.0943 | 0.0909 | 0.0870 | 0.0800 | 0.0667 | | | | | | | | | | | | | | | | | | | | | Read Accuracy (±100 ppm) | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | | Read Repetition Rate (ms) | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Min Expected COUNT Delta (LS8) | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | | Max Expected COUNT Delta (LSB) | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | | Min Actual COUNT Delta (LSB) | 4 | 7 | 8 | 8 | 9 | 9 | 9 | 9 | 9 | 10 | 10 | 10 | 10 | 10 | 11 | 12 | 14 | | Max Actual COUNT Delta (LSB) | 6 | 8 | 9 | 10 | 10 | 10 | 10 | 10 | 11 | 11 | 11 | 11 | 11 | 12 | 12 | 13 | 16 | | Pass/Fail | FAIL | FAIL | PASS FAIL | FAIL | | | | | | | | | | | | | | | | | | | | | | Case 8 | Case 7 | Case 6 | Case 5 | Case 4 | Case 3 | Case 2 | Case 1 | Case 0:<br>Normal | Case 1 | Case 2 | Case 3 | Case 4 | Case 5 | Case 6 | Case 7 | Case 8 | | Oscillator Error | -50% | -25% | -15% | -10% | -6% | -5% | -2% | -1% | 0% | 1% | 2% | 5% | 6% | 10% | 15% | 25% | 50% | | Oscillator (Hz) | 5000000 | 7500000 | 8500000 | 9000000 | 9400000 | 9500000 | 9800000 | 9900000 | 10000000 | 10100000 | 10200000 | 10500000 | 10600000 | 11000000 | 11500000 | 12500000 | 15000000 | | COUNT Resolution (ms) | 0.2000 | 0.1333 | 0.1176 | 0.1111 | 0.1064 | 0.1053 | 0.1020 | 0.1010 | 0.1000 | 0.0990 | 0.0980 | 0.0952 | 0.0943 | 0.0909 | 0.0870 | 0.0800 | 0.0667 | | | | | | | | | | | | | | | | | | | | | Read Accuracy | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | | Read Repetition Rate (ms) | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Min Expected COUNT Delta (LS8) | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | | Max Expected COUNT Delta (LSB) | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | | Min Actual COUNT Delta (LS8) | 4 | 7 | 8 | 8 | 9 | 9 | 9 | 9 | 9 | 10 | 10 | 10 | 10 | 10 | 11 | 12 | 14 | | Max Actual COUNT Delta (LSB) | 6 | 8 | 9 | 10 | 10 | 10 | 10 | 10 | 11 | 11 | 11 | 11 | 11 | 12 | 12 | 13 | 16 | | Pass/Fail | | | PASS | PASS | | | Figure 28. Oscillator verification accuracy: 1 ms read repetition rate | | Case 8 | Case 7 | Case 6 | Case 5 | Case 4 | Case 3 | Case 2 | Case 1 | Case 0:<br>Normal | Case 1 | Case 2 | Case 3 | Case 4 | Case 5 | Case 6 | Case 7 | Case 8 | |--------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|-------------------|----------|----------|----------|----------|----------|----------|----------|---------| | Oscillator Error | -50% | -25% | -15% | -10% | -6% | -5% | -2% | -1% | 0% | 1% | 2% | 5% | 6% | 10% | 15% | 25% | 50% | | Oscillator (Hz) | 5000000 | 7500000 | 8500000 | 9000000 | 9400000 | 9500000 | 9800000 | 9900000 | 10000000 | 10100000 | 10200000 | 10500000 | 10600000 | 11000000 | 11500000 | 12500000 | 1500000 | | COUNT Resolution (ms) | 0.2000 | 0.1333 | 0.1176 | 0.1111 | 0.1064 | 0.1053 | 0.1020 | 0.1010 | 0.1000 | 0.0990 | 0.0980 | 0.0952 | 0.0943 | 0.0909 | 0.0870 | 0.0800 | 0.0667 | | | | | | | | | | | | | | | | | | | | | Read Accuracy (perfect) | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | | Read Repetition Rate (ms) | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | | Min Expected COUNT Delta (LS8) | 57 | 57 | 57 | 57 | 57 | 57 | 57 | 57 | 57 | 57 | 57 | 57 | 57 | 57 | 57 | 57 | 57 | | Max Expected COUNT Delta (LSB) | 63 | 63 | 63 | 63 | 63 | 63 | 63 | 63 | 63 | 63 | 63 | 63 | 63 | 63 | 63 | 63 | 63 | | Min Actual COUNT Delta (LSB) | 30 | 45 | 51 | 54 | 56 | 57 | 58 | 59 | 60 | 60 | 61 | 63 | 63 | 66 | 69 | 75 | 90 | | Max Actual COUNT Delta (LSB) | 30 | 45 | 51 | 54 | 57 | 57 | 59 | 60 | 60 | 61 | 62 | 63 | 64 | 66 | 69 | 75 | 90 | | Pass/Fail | FAIL | FAIL | FAIL | FAIL | PASS FAIL | FAIL | FAIL | FAIL | | | | | | | | | | | | | | | | | | | | | | Case 8 | Case 7 | Case 6 | Case 5 | Case 4 | Case 3 | Case 2 | Case 1 | Case 0:<br>Normal | Case 1 | Case 2 | Case 3 | Case 4 | Case 5 | Case 6 | Case 7 | Case 8 | | Oscillator Error | -50% | -25% | -15% | -10% | -6% | -5% | -2% | -1% | 0% | 1% | 2% | 5% | 6% | 10% | 15% | 25% | 50% | | Oscillator (Hz) | 5000000 | 7500000 | 8500000 | 9000000 | 9400000 | 9500000 | 9800000 | 9900000 | 10000000 | 10100000 | 10200000 | 10500000 | 10600000 | 11000000 | 11500000 | 12500000 | 1500000 | | COUNT Resolution (ms) | 0.2000 | 0.1333 | 0.1176 | 0.1111 | 0.1064 | 0.1053 | 0.1020 | 0.1010 | 0.1000 | 0.0990 | 0.0980 | 0.0952 | 0.0943 | 0.0909 | 0.0870 | 0.0800 | 0.0667 | | • | | | | | | | | | | | | | | | | | | | Read Accuracy (±190 ppm) | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | | Read Repetition Rate (ms) | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | | Min Expected COUNT Delta (LS8) | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | | Max Expected COUNT Delta (LSB) | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | | Min Actual COUNT Delta (LSB) | 29 | 44 | 50 | 53 | 56 | 56 | 58 | 59 | 59 | 60 | 61 | 62 | 63 | 65 | 68 | 74 | 89 | | Max Actual COUNT Delta (LSB) | 31 | 46 | 52 | 55 | 57 | 58 | 59 | 60 | 61 | 61 | 62 | 64 | 64 | 67 | 70 | 76 | 91 | | Pass/Fail | FAIL | FAIL | FAIL | FAIL | PASS FAIL | FAIL | FAIL | FAIL | | - | | | | | | | | | | | | | | | | | | | | Case 8 | Case 7 | Case 6 | Case 5 | Case 4 | Case 3 | Case 2 | Case 1 | Case 0:<br>Normal | Case 1 | Case 2 | Case 3 | Case 4 | Case 5 | Case 6 | Case 7 | Case 8 | | Oscillator Error | -50% | -25% | -15% | -10% | -6% | -5% | -2% | -1% | 0% | 1% | 2% | 5% | 6% | 10% | 15% | 25% | 50% | | Oscillator (Hz) | 5000000 | 7500000 | 8500000 | 9000000 | 9400000 | 9500000 | 9800000 | 9900000 | 10000000 | 10100000 | 10200000 | 10500000 | 10600000 | 11000000 | 11500000 | 12500000 | 1500000 | | COUNT Resolution (ms) | 0.2000 | 0.1333 | 0.1176 | 0.1111 | 0.1064 | 0.1053 | 0.1020 | 0.1010 | 0.1000 | 0.0990 | 0.0980 | 0.0952 | 0.0943 | 0.0909 | 0.0870 | 0.0800 | 0.0667 | | | | | | | | | | | | | | | | | | | | | Read Accuracy | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | | Read Repetition Rate (ms) | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | | Min Expected COUNT Delta (LS8) | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | 56 | | Max Expected COUNT Delta (LSB) | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | 64 | | Min Actual COUNT Delta (LSB) | 29 | 44 | 50 | 53 | 55 | 56 | 58 | 58 | 59 | 60 | 60 | 62 | 62 | 65 | 68 | 74 | 89 | | Max Actual COUNT Delta (LSB) | 31 | 46 | 52 | 55 | 57 | 58 | 60 | 60 | 61 | 62 | 62 | 64 | 65 | 67 | 70 | 76 | 91 | | | | | | | | | | | | | | | | | | | | Figure 29. Oscillator verification accuracy: 6 ms read repetition rate | Case | | | | | | | | | | | | | | | | | | - | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | Concision (riv) 0,0000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 0,00000 | | Case 8 | Case 7 | Case 6 | Case 5 | Case 4 | Case 3 | Case 2 | Case 1 | | Case 1 | Case 2 | Case 3 | Case 4 | Case 5 | Case 6 | Case 7 | Case 8 | | COUNT Resolution (ms) 0.2000 0.1333 0.1176 0.1111 0.1064 0.1053 0.1070 0.1010 0.1000 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 0.0990 | Oscillator Error | -50% | -25% | -15% | -10% | -6% | -5% | -2% | -1% | 0% | 1% | 2% | 5% | 6% | 10% | 15% | 25% | 50% | | Read Accuracy (perfect) | Oscillator (Hz) | 5000000 | 7500000 | 8500000 | 9000000 | 9400000 | 9500000 | 9800000 | 9900000 | 10000000 | 10100000 | 10200000 | 10500000 | 10600000 | 11000000 | 11500000 | 12500000 | 15000000 | | Read Repertision Rizer (ray) 74 | COUNT Resolution (ms) | 0.2000 | 0.1333 | 0.1176 | 0.1111 | 0.1064 | 0.1053 | 0.1020 | 0.1010 | 0.1000 | 0.0990 | 0.0980 | 0.0952 | 0.0943 | 0.0909 | 0.0870 | 0.0800 | 0.0667 | | Read Repertision Rizer (ray) 74 | | | | | | | | | | | | | | | | | | | | Man Exposed COUNT Defair (158) 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 228 2 | Read Accuracy (perfect) | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | 0.0% | | Max Equated COUNT Data (158) 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 252 | Read Repetition Rate (ms) | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | | Min Actual COUNT Defin (ISS) 120 180 204 216 225 228 236 228 237 240 242 244 252 255 264 276 300 360 | Min Expected COUNT Delta (LS8) | 228 | 228 | 228 | 228 | 228 | 228 | 228 | 228 | 228 | 228 | 228 | 228 | 228 | 228 | 228 | 228 | 228 | | Max Actual COUNT Delta (ISS) 120 | Max Expected COUNT Delta (LSB) | 252 | 252 | 252 | 252 | 252 | 252 | 252 | 252 | 252 | 252 | 252 | 252 | 252 | 252 | 252 | 252 | 252 | | Pam/Fall 131 | Min Actual COUNT Delta (LSB) | 120 | 180 | 204 | 216 | 225 | 228 | 235 | 237 | 240 | 242 | 244 | 252 | 254 | 264 | 276 | 300 | 360 | | Case 8 Case 7 Case 6 Case 5 Case 4 Case 5 Case 4 Case 5 Case 6 6 Case 5 6 Case 5 Case 6 Case 5 Case 6 Case 6 Case 5 Case 6 Case 5 Case 6 Case 6 Case 5 Case 6 C | Max Actual COUNT Delta (LSB) | 120 | 180 | 204 | 216 | 226 | 228 | 236 | 238 | 240 | 243 | 245 | 252 | 255 | 264 | 276 | 300 | 360 | | Confishor Error Case Cas | Pass/Fail | FAIL | FAIL | FAIL | FAIL | FAIL | PASS FAIL | FAIL | FAIL | FAIL | FAIL | | Confishor Error Case Cas | - | | | | | | | | | | | | | | | | | | | Count Coun | | Case 8 | Case 7 | Case 6 | Case 5 | Case 4 | Case 3 | Case 2 | Case 1 | | Case 1 | Case 2 | Case 3 | Case 4 | Case 5 | Case 6 | Case 7 | Case 8 | | COUNT Resolution (mw) 0.2000 0.1333 0.1176 0.1111 0.1064 0.1053 0.1007 0.1010 0.1000 0.0990 0.0890 0.0980 0.0992 0.0943 0.0990 0.0870 0.0800 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0.08067 0 | Oscillator Error | -50% | -25% | -15% | -10% | -6% | -5% | -2% | -1% | 0% | 1% | 2% | 5% | 6% | 10% | 15% | 25% | 50% | | Read Accuracy (±100 ppm) | Oscillator (Hz) | 5000000 | 7500000 | 8500000 | 9000000 | 9400000 | 9500000 | 9800000 | 9900000 | 10000000 | 10100000 | 10200000 | 10500000 | 10600000 | 11000000 | 11500000 | 12500000 | 15000000 | | Read Repetition Rate (rm) A4 24 24 24 24 24 24 24 24 24 24 24 24 24 | COUNT Resolution (ms) | 0.2000 | 0.1333 | 0.1176 | 0.1111 | 0.1064 | 0.1053 | 0.1020 | 0.1010 | 0.1000 | 0.0990 | 0.0980 | 0.0952 | 0.0943 | 0.0909 | 0.0870 | 0.0800 | 0.0667 | | Read Repetition Rate (rm) A4 24 24 24 24 24 24 24 24 24 24 24 24 24 | | | | | | | | | | | | | | | | | | | | Min Exposed COUNT Defair (159) 27 27 27 27 27 27 27 27 27 27 27 27 27 | Read Accuracy (±198 ppm) | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | 0.0100% | | Max Epaceted COUNT Deha (189) | Read Repetition Rate (ms) | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | | Min Actual COUNT Defas (158) 119 179 203 215 225 225 225 225 226 238 241 242 244 251 253 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 | Min Expected COUNT Delta (LS8) | 227 | 227 | 227 | 227 | 227 | 227 | 227 | 227 | 227 | 227 | 227 | 227 | 227 | 227 | 227 | 227 | 227 | | Max Actual COUNT Delta (ISS) 121 181 205 217 226 229 226 238 241 243 245 253 255 265 277 301 361 | Max Expected COUNT Delta (LSB) | 253 | 253 | 253 | 253 | 253 | 253 | 253 | 253 | 253 | 253 | 253 | 253 | 253 | 253 | 253 | 253 | 253 | | Pass/Fail Fail Fa | Min Actual COUNT Delta (LSB) | 119 | 179 | 203 | 215 | 225 | 227 | 235 | 237 | 239 | 242 | 244 | 251 | 254 | 263 | 275 | 299 | 359 | | Company Comp | Max Actual COUNT Delta (LSB) | 121 | 181 | 205 | 217 | 226 | 229 | 236 | 238 | 241 | 243 | 245 | 253 | 255 | 265 | 277 | 301 | 361 | | Confision Case Ca | Pass/Fail | | | | | | PASS | | | | | | Confision Case Ca | | | | | | | | | | | | | | | | | | | | Coulimer (Feb 200000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 5000000 50000000 5000000 5000000 5000000 500000 500000 500000 500000 | | Case 8 | Case 7 | Case 6 | Case 5 | Case 4 | Case 3 | Case 2 | Case 1 | | Case 1 | Case 2 | Case 3 | Case 4 | Case 5 | Case 6 | Case 7 | Case 8 | | COUNT Resolution (ms) 0.2000 0.1333 0.1176 0.1111 0.1064 0.1053 0.1020 0.1010 0.1000 0.0990 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0.0980 0 | Oscillator Error | -50% | -25% | -15% | -10% | -6% | -5% | -2% | -1% | 0% | 1% | 2% | 5% | 6% | 10% | 15% | 25% | 50% | | Read Accuracy 1.0% 1.0% 1.0% 1.0% 1.0% 1.0% 1.0% 1.0% | Oscillator (Hz) | 5000000 | 7500000 | 8500000 | 9000000 | 9400000 | 9500000 | 9800000 | 9900000 | 10000000 | 10100000 | 10200000 | 10500000 | 10600000 | 11000000 | 11500000 | 12500000 | 15000000 | | Read Repetition Flate (rul) 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 <t< th=""><th>COUNT Resolution (ms)</th><th>0.2000</th><th>0.1333</th><th>0.1176</th><th>0.1111</th><th>0.1064</th><th>0.1053</th><th>0.1020</th><th>0.1010</th><th>0.1000</th><th>0.0990</th><th>0.0980</th><th>0.0952</th><th>0.0943</th><th>0.0909</th><th>0.0870</th><th>0.0800</th><th>0.0667</th></t<> | COUNT Resolution (ms) | 0.2000 | 0.1333 | 0.1176 | 0.1111 | 0.1064 | 0.1053 | 0.1020 | 0.1010 | 0.1000 | 0.0990 | 0.0980 | 0.0952 | 0.0943 | 0.0909 | 0.0870 | 0.0800 | 0.0667 | | Read Repetition Flate (rul) 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 24 <t< th=""><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th></t<> | | | | | | | | | | | | | | | | | | | | Min Expected COUNT Defar (158) 25 25 25 25 25 25 25 25 25 25 25 25 25 | Read Accuracy | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | 1.0% | | Max Expected COUNT Delta (LSB) 255 255 255 255 255 255 255 255 255 25 | Read Repetition Rate (ms) | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | | Min Actual COUNT Delta (ISS) 118 178 201 213 223 225 232 243 240 242 249 251 261 273 297 356 Max Actual COUNT Delta (ISS) 122 182 207 219 228 231 233 240 243 245 248 255 257 267 279 304 364 | Min Expected COUNT Delta (LSB) | 225 | 225 | 225 | 225 | 225 | 225 | 225 | 225 | 225 | 225 | 225 | 225 | 225 | 225 | 225 | 225 | 225 | | Max Actual COUNT Delta (188) | Max Expected COUNT Delta (LSB) | 255 | 255 | 255 | 255 | 255 | 255 | 255 | 255 | 255 | 255 | 255 | 255 | 255 | 255 | 255 | 255 | 255 | | | | | | | | | | | | | | | | | | | | | | Pase/Foil FAIL FAIL FAIL PASS PASS PASS PASS PASS PASS PASS PAS | Max Actual COUNT Delta (LSB) | 122 | 182 | 207 | 219 | 228 | 231 | 238 | 240 | 243 | 245 | 248 | 255 | 257 | 267 | 279 | 304 | 364 | | | Pass/Fail | FAIL | FAIL | FAIL | FAIL | PASS FAIL | FAIL | FAIL | FAIL | Figure 30. Oscillator verification accuracy: 24 ms read repetition rate #### SPI Communication Procedure Recommendations for the FXLS9xxxx # 10 Optional User Diagnostics This section describes some additional system level diagnostics that can be used to improve the safety performance of the device in its intended application. These diagnostics are not inherent in the device and, if used, must be conducted externally. ### 10.1 Continuous railed output detection Using the sensor data from each source collected during normal mode, the following procedure can be used to detect a railed output. The example procedure uses the configurations described in this application note and is documented for only one data source, although it should be completed on each data source. AN12386 #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 10.2 Continuous sustained step detection Using the sensor data from each source collected during normal mode, the following procedure can be used to detect a sustained step on the output. The example procedure uses the configurations described in this application note. Step detection limits are gain, range, and application dependent. Therefore, the user must determine the limits for the step detection based on the application. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 10.3 Normal Mode memory protection verification When ENDINIT is set, the UF2 user memory block is locked and verified via CRC as described in the datasheet. The following procedure tests the memory lock to confirm that writes to the UF2 array are prevented. In this example, the PDCM\_RSPST3 registers are used for memory protection verification as they are unused for the SPI application. Other registers can be used as long as the function for the register being written to is considered. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 11 Bus Contention Considerations Certain SPI failure modes on the FXLS9xxxx can prevent or corrupt communication from other devices on the SPI bus. Likewise, some SPI failure modes of other devices on the SPI bus can prevent or corrupt communication from the FXLS9xxxx device(s). The following internal safety mechanisms enable the detection of corrupted communication to and from the FXLS9xxxx device(s) due to a failure mode from another device on the SPI bus. Reference the datasheet for more details on each safety mechanism. - 1. SPI MOSI CRC verification - 2. Verification of SCLK low when SS B is asserted - 3. Verification of SCLK low when SS\_B is deasserted - 4. Verification that the number of SCLKs while SS\_B is asserted is exactly 32 - 5. SPI MOSI fixed bit verification for all commands - The device verifies the state of all non-command and non-CRC bits in a command. Thus, all 32 SPI bits are verified. - 6. SPI Sensor Data Request SOURCEID verification - The source of the data is verified against the requested SOURCEID prior to transmission. If a mismatch occurs, an error message is transmitted instead of sensor data. - 7. SPI MISO Error Detection The following external safety mechanisms are required to enable the detection of corrupted communication from the FXLS9xxxx device(s) due to a failure mode from another device on the SPI bus. - 1. SPI MISO CRC verification - 2. SPI sensor data SOURCEID verification The following external safety mechanisms are optional to improve the detection of corrupted communication from the FXLS9xxxx device(s) due to a failure mode from another device on the SPI bus. - 1. SPI MISO fixed bit verification for all commands - 2. SPI sensor data message counter(s) verification for 4-bit CRC implementation #### SPI Communication Procedure Recommendations for the FXLS9xxxx # 12 Summary and Conclusion This application note describes the recommended procedures for initializing and configuring FXLS9xxx devices on a SPI bus, completing self-test on the devices, and transitioning the devices to Normal Mode. These recommended procedures are essential to meeting the functional safety requirements of the intended system. #### SPI Communication Procedure Recommendations for the FXLS9xxxx # 13 Appendix ## 13.1 SPI state transition diagram Figure 34 shows a state transition diagram for the internal SPI controller. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 13.2 SPI startup error response timing Figure 35 shows a representative timing diagram for SPI Start Up error conditions. ## 13.3 Internal error response timing #### 13.3.1 Standard internal error conditions: transient Figure 36 shows a representative timing diagram for transient internal error conditions. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 13.3.2 Standard internal error conditions: persistent Figure 37 shows a representative timing diagram for persistent internal error conditions. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 13.3.3 Apparent external error conditions: transient <u>Figure 38</u> shows a representative timing diagram for apparent transient external error conditions. ## 13.3.4 Apparent external error conditions: persistent <u>Figure 39</u> shows a representative timing diagram for apparent Persistent external error conditions. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 13.3.5 Supply errors: transient Figure 40 shows a representative timing diagram for transient supply error conditions. ## 13.4 Example SPI command list The commands and responses for the sequence used in this application note are summarized below, all using the 8-bit CRC. | Line # | End Time<br>(ms) | Description | Command<br>HEX | Response<br>HEX | |--------|------------------|------------------------------------------------|----------------------------------------|--------------------------| | 1 | (IIIS) | | 0xC00000D1 | 0x0C0002FB | | 2 | 1 | | 0xC00000D1 | 0x0C0002FB | | 3 | 0.1 | Read DEVSTAT / COUNT | 0xC00000D1 | 0x60C0AC1B | | 4 | 1 | | 0xC00000D1 | 0x60C0AD34 | | 5 | | | 0x80100005 | 0x440080C7 | | 6 | 0.2 | Soft Reset | 0x80100374 | 0x440083B6 | | 7 | 0.2 | Soit Reset | 0x80100374 | 0x00000000 | | 8 | | | 0xC00000D1 | 0x0C0002FB | | 9 | 1 | | 0xC00000D1 | 0x0C0002FB | | 10 | 1.5 | Read DEVSTAT / COUNT | 0xC00000D1 | 0x60C10A80 | | 11 | 1 | | 0xC0000D1 | 0x60C10A80 | | 12 | 1.5 | Configure CDI: 9 b# CDC | | | | 13 | 1.0 | Configure SPI: 8-bit CRC | 0x803D00F6 | 0x4000001C<br>0x60C10E3C | | 14 | 1 | | 0x802C55E1<br>0xC02C00CB | | | | | | | 0x400055C7 | | 15 | | D -14 - D # - 141 3 | 0x802CAAA3 | 0x60005528 | | 16 | 2.0 | Register Pattern Write<br>Repeat up to 3 times | 0xC02C00CB | 0x4000AA85 | | 17 | | | 0x802CFF78 | 0x6000AA6A | | 18 | | | 0xC02C00CB | 0x4000FF5E | | 19 | | | 0x802C003A | 0x6000FFB1 | | 20 | | | 0xC02C00CB | 0x4000001C | | 21 | | | 0x801A809E | 0x400080FF | | 22 | 2.5 | Configure Data Sources | 0x801B8158 | 0x40818011 | | 23 | | comgare som comes | 0x801C82E8 | 0x400082A1 | | 24 | | | 0x801D832E | 0x408382B2 | | 25 | | | 0x80408057 | 0x60C11B01 | | 26 | | | 0x8041F085 | 0x400080FF | | 27 | 1 | | 0x80422264 | 0x40F08003 | | 28 | 20 | Configure S Si | 0x8043100E | 0x40002231 | | 29 | 3.0 | Configure Sensor Signals | 0x804883A3 | 0x40102214 | | 30 | | | 0x8049F000 | 0x4000838E | | 31 | 1 | | 0x804A22E1 | 0x40F08372 | | 32 | | | 0x804B0025 | 0x40002231 | | 33 | | Read DEVSTAT / COUNT | 0xC00000D1 | 0x60C11870 | | 34 | 9.0 | 6ms | | | | 35 | | Oscillator Verification | 0xC00000D1 | 0x60C05494 | | 36 | | | 0x8014C0D5 | 0x40E0C0C0 | | 37 | 1 | | 0xC0C00042 | 0x602603E0 | | 38 | 1 | | 0xC0C200BF | 0x600002AD | | 39 | 1 | | 0xC0C40097 | 0x600322CA | | 40 | | | 0xC0C6006A | 0x6045CA57 | | 41 | | | 0xC0C800C7 | 0x60004B33 | | 42 | | | 0xC0CA003A | 0x601600FE | | 43 | 1 | | | 0x602B0A21 | | 44 | 11.0 | 0 Read Traceability Information 0xC0CC0012 | 0x8014D07B | 0x40C0D024 | | 45 | 1 | | 0xC0D00067 | 0x601FCE22 | | 46 | 1 | | 0xC0D2009A | 0x600000F3 | | 47 | 1 | | 0xC0D400B2 | 0x600000F3 | | 48 | 1 | | 0xC0D6004F | 0x600000F3 | | 49 | 1 | | | | | | 1 | | 0xC0D800E2 | 0x600000F3 | | 50 | | | 0xC0DA001F | 0x600000F3 | | 51 | | | 0xC0DD00DE | 0x600000F3 | | 52 | | | 0x8014A040 | 0x40D0A03A | | 53 | | 12.0 Read Stored Self-Test Values | 0xC0A40049 | 0x60054358 | | 54 | 12.0 | | 0xC0A80019 | 0x60051DA5 | | 55 | | | 0x8014B0EE | 0x40A0B06F | | 56 | | | 0xC0B4006C | 0x60052F26 | | 57 | | | 0xC0B8003C | 0x6005062D | | 58 | | | 0xC01600DC | 0x600000F3 | | 59 | | | 0xC0180071 | 0x600000F3 | | 60 | - | | 0xC01A008C | 0x608180FE | | 61 | | | 0xC01C00A4 | 0x6083825D | | 62 | | | 0xC01E0059<br>0xC020009B<br>0xC0220066 | 0x600000F3 | | 63 | | | | 0x600000F3 | | 64 | | | | 0x600000F3 | | 65 | 13.0 | Read Verify | · · · · · · · · · · · · · · · · · · · | 0x60A7007F | | 66 | | | 0xC04200B8 | 0x60122058 | | 67 | | | 0xC0440090 | 0x600000F3 | | 68 | | | 0xC046006D | 0x601111BE | | 69 | | | 0xC04800C0 | 0x60FF033A | | 70 | | | 0xC04A003D | 0x6002207D | | 71 | | | 0xC04C0015 | 0x600000F3 | | 72 | | | 0xC04E00E8 | 0x60A5A581 | | 73 | | | 0xC00000D1 | 0x6000073E | | 74 | | | 0x1000000D | 0x60C1392C | | 75 | | | 0x300000E2 | 0x80000020 | | 76 | | 43.0 Read Offset for ~ 30ms | 0x500000FC | 0x93FF8089 | | 77 | 43.0 | | 0x70000013 | 0xA00E0062 | | 78 | 15.0 | | 0xC06200F2 | 0xB00040C9 | | 79 | | | 0xC06400DA | 0x600001DC | | 80 | 1 | | 0xC07200D7 | 0x60FFFE26 | | 81 | 1 | | 0xC07400FF | 0x600071E7 | | | | | | | | Line # | End Time | Description | Command | Response | |------------|----------|-------------------------------------------------------------------------|--------------------------|--------------------------| | | (ms) | 2000.ipuo.i | HEX | HEX | | 82 | | | 0x80445029 | 0x40005054 | | 83 | | | 0x804C6071 | 0x480060F9 | | 84<br>85 | ł | | 0x1000000D<br>0x300000E2 | 0x8AAA809A | | 86 | 1 | | 0x500000E2 | 0x9AAA807A<br>0xA95540DA | | 87 | 1 | | 0x70000013 | 0xB955403A | | 88 | 1 | | 0xC06200F2 | 0x68AAAA2F | | 89 | 1 | | 0xC06400DA | 0x68AAAA2F | | 90 | 1 | | 0xC07200D7 | 0x685555D5 | | 91 | 1 | | 0xC07400FF | 0x685555D5 | | 92 | 44.0 | Fixed Pattern Self Test | 0xC00000D1 | 0x6800955D | | 93 | | | 0x804460F4 | 0x480060F9 | | 94 | | | 0x804C50AC | 0x48005024 | | 95 | 1 | | 0x1000000D | 0x89554035 | | 96 | | | 0x300000E2 | 0x995540D5 | | 97 | | | 0x500000FC | 0xAAAA8075 | | 98<br>99 | | | 0x70000013 | 0xBAAA8095 | | 100 | - | | 0xC06200F2<br>0xC06400DA | 0x685555D5<br>0x685555D5 | | 101 | ł | | 0xC07200D7 | 0x68AAAA2F | | 102 | 1 | | 0xC07400FF | 0x68AAAA2F | | 103 | FC - | Enable Digital Self-Test | 0x8044F0B9 | 0x4800F0B4 | | 104 | 56.0 | Delay 12 ms | 0x804CF03C | 0x4800F0B4 | | 105 | | | 0x1000000D | 0x88F7006D | | 106 | ] | | 0x300000E2 | 0x98F7008D | | 107 | ] | Read Sensor Data for ~30ms | 0x500000FC | 0xA8F70082 | | 108 | | ] | 0x70000013 | 0xB8EF4024 | | 109 | 86.0 | Note, multiple reads not necessary. | 0xC06200F2 | 0x6807B904 | | 110 | | Repeated Reads were used to confirm | 0xC06400DA | 0x6807B82B | | 111 | | constant data | 0xC07200D7 | 0x6807B904 | | 112<br>113 | - | | 0xC07400FF<br>0xC00000D1 | 0x68077A70<br>0x6800187A | | 113 | | Enable Analog Self-Test Phase 1 | 0x8044A0F1 | 0x4800A0FC | | 115 | 98.0 | Delay 12 ms | 0x804CB0DA | 0x4800B052 | | 116 | | Doug 12 IIIS | 0x1000000D | 0x884E408F | | 117 | 1 | | 0x300000E2 | 0x984E0089 | | 118 | 1 | Read Sensor Data for ~30ms | 0x500000FC | 0xAA004045 | | 119 | 1 | N-4 CNCDATA Ch | 0x70000013 | 0xBA0040A5 | | 120 | 128.0 | Note: SNSDATA registers, Channel<br>Status and Sensor Data Requests all | 0xC06200F2 | 0x680274F9 | | 121 | | read to confirm consistency. All are | 0xC06400DA | 0x6802721B | | 122 | | not necessary | 0xC07200D7 | 0x68EB7381 | | 123 | | | 0xC07400FF | 0x68EAFAF3 | | 124 | | | 0xC00000D1 | 0x680045F6 | | 125 | 133.0 | Enable Analog Self-Test Phase 2 | 0x8044B05F | 0x4800B052 | | 126<br>127 | | Delay 5 ms | 0x804CA074<br>0x1000000D | 0x4800A0FC | | 128 | 1 | | 0x300000E2 | 0x8BAD00B6<br>0x9BAD0056 | | 129 | 1 | Read Sensor Data for ~30ms | 0x500000E2 | 0xA9FFC00C | | 130 | 1 | | 0x70000013 | 0xB9FFC0EC | | 131 | 163.0 | Note: SNSDATA registers, Channel | 0xC06200F2 | 0x68FD6A5A | | 132 | 1 | Status and Sensor Data Requests all | 0xC06400DA | 0x68FD6804 | | 133 | 1 | read to confirm consistency. All are not necessary | 0xC07200D7 | 0x6815A85D | | 134 | ] | IRC IRCUSSRIY | 0xC07400FF | 0x68152AE0 | | 135 | | | 0xC00000D1 | 0x68005629 | | 136 | 263.0 | Reset Offset Cancellation Startup | 0x804390ED | 0x40902213 | | 137 | | Delay 100 ms | 0x804B80C6 | 0x40802236 | | 138 | | | 0x1000000D | 0x80000020 | | 139 | | Read Sensor Data for ~20ms | 0x300000E2 | 0x93FFC06F | | 140<br>141 | - | _ | 0x500000FC | 0xA00F8068<br>0xB00040C9 | | 141 | 283.0 | Note: SNSDATA registers, Channel | 0x70000013<br>0xC06200F2 | 0x600040C9<br>0x600002AD | | 143 | 200.0 | Status and Sensor Data Requests all | 0xC06400DA | 0x600002AD<br>0x600000F3 | | 143 | 1 | read to confirm consistency. All are | 0xC07200D7 | 0x6000824E | | 145 | 1 | not necessary | 0xC07400FF | 0x60000382 | | 146 | 1 | <u> </u> | 0xC00000D1 | 0x6000AFF9 | | 147 | 284.0 | Set ENDINIT | 0x801080E6 | 0x400080FF | | 148 | | | 0x1000000D | 0x840040FE | | 149 | | Normal Made Lean | 0x300000E2 | 0x940000F8 | | 150 | | Normal Mode Loop | 0x500000FC | 0xA4108031 | | 151 | | Note: SNSDATA registers, Channel | 0x70000013 | 0xB40080F4 | | 152 | | Status and Sensor Data Requests all | 0xC06200F2 | 0x64000295 | | 153 | | read to confirm consistency. All are | 0xC06400DA | 0x640000CB | | 154 | - | not necessary | 0xC07200D7 | 0x64008276 | | 155<br>156 | 1 | | 0xC07400FF<br>0xC00000D1 | 0x640001E4<br>0x64000558 | | 130 | I | | ONCOOUDD I | OCCUDITOR | #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 13.5 CRC calculation examples ## 13.5.1 8-bit CRC Figure 41 shows some example visual basic to calculate the SPI 8-bit CRC. - Function SPICRC8(Data32 As String, Poly As String, SEED As String) As String - Data32 is the 24-bit message in binary to be verified with 8 zeroes appended in place of the CRC Example: Command = 0x804013xx: Data32 = 1000 0000 0100 0000 0001 0011 0000 0000 • Poly is the 9-bit CRC polynomial in binary Example: Polynomial = $X^8+X^5+X^3+X^2+X+1$ Poly = 1 0010 1111 • SEED is the 8-bit CRC Initial value in binary Example: Seed = 0xFF SEED = 1111 1111 In this example, the CRC = 0x6B ``` | Function SPICRC8(bata32 As String, Poly As String, SEED As String) | As String | Dim in As Integer | Dim in As Integer | Dim in As Integer | Dim in As Integer | Dim bit As Integer | Dim bit As Integer | Dim bit As Integer | Dim bit As Integer | Dim CRC(1 To 8) As String | Dim CRC(1 To 8) As String | Dim CRC(1 To 8) As String | Dim CRC(1 To 8) As String | Dim CRC(0) = Mid(SEED, i, 1) | CRC_0d(i) = Mid(SEED, i, 1) | CRC_0d(i) = Mid(SEED, i, 1) | CRC_0d(i) = Mid(SEED, i, 1) | CRC_0d(i) = Mid(SEED, i, 1) | CRC_0d(i) = Mid(SEED, i, 1) | Else | If bit = 1 Then | CRC(m) = 1 | Else | If bit = 1 Then | CRC(m) = 1 | Else | If bit = 1 Then | CRC(m) = 1 | Else | If bit = 1 Then | CRC(m) = 1 | Else | If bit = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | CRC(m) = 1 | Else | If CRC_0d(i) = 1 Then | If CRC_0d(i) = 1 Then | CRC_0d(i) = 1 Then | If ``` Figure 41. SPI, 8-bit CRC Visual Basic #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 13.5.2 4-bit CRC Figure 42 shows some example visual basic to calculate the SPI 4-bit CRC. - Function SPICRC4(Data32 As String, Poly As String, SEED As String) As String - Data32 is the 24-bit message in binary to be verified with 8 zeroes appended in place of the CRC Example: Command = 0x8040130x: Data32 = 1000 0000 0100 0000 0001 0011 0000 0000 • Poly is the 9-bit CRC polynomial in binary Example: Polynomial = $X^4$ +1 Poly = 1 0001 • SEED is the 8-bit CRC Initial value in binary Example: Seed = 0xA SEED = 1010 In this example, the CRC = 0x4 ``` Function SPICRC4(Data32 As String, Poly As String, SEED As String) As String Dim I As Integer Dim m As Integer Dim n As Integer Dim k As Integer Dim bit As Integer Dim bit As Integer Dim bit As Integer Dim Dim CRC (Did (To 4) As String Dim CRC, Old (To 4) As String Dim CRC, Old (To 4) As String Dim CRC, Old (To 4) As String For i = 1 To 4 CRC(i) = Mid(SEED, i, 1) CRC, Old (j) = Mid(SEED, i, 1) Next i For n = 1 To 32 bit = Mid(Data32, n, 1) For k = 1 To 4 CRC, Old (k) = CRC(k) Next k Figure 1 Then CRC, Old (i) = Mid(SEED, i) CRC, Old (i) = Mid(SEED, i) Dim ( ``` Figure 42. SPI, 4-bit CRC Visual Basic #### SPI Communication Procedure Recommendations for the FXLS9xxxx #### 13.5.3 3-bit CRC Figure 43 shows some example visual basic to calculate the SPI 3-bit CRC. - Function SPICRC3(Data32 As String, Poly As String, SEED As String) As String - Data32 is the 29-bit message in binary to be verified with 3 zeroes appended in place of the CRC Example: Command = 0x8040270x: Data32 = 1000 0000 0100 0000 0010 0111 0000 0000 • Poly is the 9-bit CRC polynomial in binary Example: Polynomial = $X^3+X+1$ Poly = 1011 • SEED is the 8-bit CRC Initial value in binary Example: Seed = 0x7 SEED = 111 In this example, the CRC = 0x5 ``` Function SPICRC3(Data32 As String, Poly As String, SEED As String) As String Dim i As Integer Dim m As Integer Dim m As Integer Dim k As Integer Dim bit As Integer i = 1 m = 1 m = 1 ht = 0 Dim CRC(1 To 3) As String Dim CRC, old(1 To 3) As String Dim CRC, old(1 To 3) As String Dim CRC, old(1 To 3) As String For m = 1 To 32 Dim CRC, old(1 SEED, i, 1) CRC, old(1) = Mid(SEED, i, 1) Nont. For m = 1 To 32 Dim CRC, old(k) = CRC(k) Next k For m = 1 To 3 CRC, old(k) = CRC(k) Ref(m) = 0 End if Else GRC(m) Els ``` Figure 43. SPI, 3-Bit CRC Visual Basic #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## 14 Legal information #### 14.1 Definitions **Draft** — A draft status on a document indicates that the content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included in a draft version of a document and shall have no liability for the consequences of use of such information. #### 14.2 Disclaimers Limited warranty and liability - Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. NXP Semiconductors takes no responsibility for the content in this document if provided by an information source outside of NXP Semiconductors. In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation - lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory. Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms and conditions of commercial sale of NXP Semiconductors. Right to make changes — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof. Suitability for use — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in life support, life-critical or safety-critical systems or equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors and its suppliers accept no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk. Applications — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification. Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors product is suitable and fit for the customer's applications and products planned, as well as for the planned application and use of customer's third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products. NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on any weakness or default in the customer's applications or products, or the application or use by customer's third party customer(s). Customer is responsible for doing all necessary testing for the customer's applications and products using NXP Semiconductors products in order to avoid a default of the applications and the products or of the application or use by customer's third party customer(s). NXP does not accept any liability in this **Export control** — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from competent authorities. **Translations** — A non-English (translated) version of a document is for reference only. The English version shall prevail in case of any discrepancy between the translated and English versions. Security — While NXP Semiconductors has implemented advanced security features, all products may be subject to unidentified vulnerabilities. Customers are responsible for the design and operation of their applications and products to reduce the effect of these vulnerabilities on customer's applications and products, and NXP Semiconductors accepts no liability for any vulnerability that is discovered. Customers should implement appropriate design and operating safeguards to minimize the risks associated with their applications and products. #### 14.3 Trademarks Notice: All referenced brands, product names, service names and trademarks are the property of their respective owners. #### SPI Communication Procedure Recommendations for the FXLS9xxxx ## **Tables** | | <u> </u> | | | |----------|---------------------------------------------------|----------|-----------------------------------------------------| | Tab. 1. | Applicable parts1 | Tab. 13. | Standard offset verification test limits, high g 38 | | Tab. 2. | Definition list | Tab. 14. | Offset measured values | | Tab. 3. | Revision history2 | Tab. 15. | Standard self-test verification test limits, | | Tab. 4. | 8-bit CRC 4 | | medium g X-axis40 | | Tab. 5. | 4-bit CRC 4 | Tab. 16. | Standard self-test verification test limits, | | Tab. 6. | 3-bit CRC | | medium g Z-axis41 | | Tab. 7. | Source Identifier registers | Tab. 17. | Standard self-test verification test limits, | | Tab. 8. | Signal chain low pass filter selection17 | | high g X-axis42 | | Tab. 9. | Signal chain user gain selection18 | Tab. 18. | Standard self-test verification test limits, | | Tab. 10. | Datatype configuration19 | | high g Z-axis43 | | Tab. 11. | Data sheet digital self-test values with | Tab. 19. | | | | minimum gain31 | | limits44 | | Tab. 12. | Standard offset verification test limits, | Tab. 20. | Oscillator verification accuracy summary 47 | | | medium g | | | | | - | | | | Figur | 96 | | | | ı ıguı | <del></del> | | | | Fig. 1. | Example SPI supply ramp3 | Fig. 23. | Mid self-test offset34 | | Fig. 2. | Example SPI initialization timing diagram3 | Fig. 24. | Channel 0 negative self-test, Channel 1 | | Fig. 3. | High level SPI flow chart for the FXLS9xxxx 5 | 9 | positive self-test | | Fig. 4. | Complete a soft reset6 | Fig. 25. | Post self-test offset | | Fig. 5. | Confirm device status7 | Fig. 26. | Restart offset cancellation fast startup 45 | | Fig. 6. | DEVSTAT register mapping8 | Fig. 27. | Transition to Normal Mode46 | | Fig. 7. | Configure SPI9 | Fig. 28. | Oscillator verification accuracy: 1 ms read | | Fig. 8. | Complete register pattern write verification 11 | Ü | repetition rate47 | | Fig. 9. | Configure the data sources12 | Fig. 29. | Oscillator verification accuracy: 6 ms read | | Fig. 10. | Data source mapping diagram13 | · · | repetition rate48 | | Fig. 11. | Configure the sensor signal chain16 | Fig. 30. | Oscillator verification accuracy: 24 ms read | | Fig. 12. | Confirm device oscillator: coarse verification 20 | · · | repetition rate48 | | Fig. 13. | Confirm device traceability information21 | Fig. 31. | Continuous railed output detection49 | | Fig. 14. | Read and record the stored self-test data 22 | Fig. 32. | Continuous sustained step detection 50 | | Fig. 15. | Confirm the device configuration24 | Fig. 33. | Normal Mode memory protection verification51 | | Fig. 16. | Self-test overview25 | Fig. 34. | SPI state transition diagram54 | | Fig. 17. | Pre-self-test offset27 | Fig. 35. | SPI start up error conditions 55 | | Fig. 18. | Complete fixed value self-test29 | Fig. 36. | Standard internal error conditions: transient 55 | | Fig. 19. | Complete digital self-test30 | Fig. 37. | Standard internal error conditions: persistent56 | | Fig. 20. | Example analog self-test response, Channel | Fig. 38. | External error conditions: transient57 | Fig. 21. Fig. 22. Fig. 39. Fig. 40. Fig. 41. Fig. 42. Fig. 43. negative self-test ......33 Example analog self-test response, Channel Channel 0 positive self-test, Channel 1 External error conditions: persistent ......57 Supply Error Conditions: Transient ...... 58 SPI, 8-bit CRC Visual Basic ......61 SPI, 4-bit CRC Visual Basic ......62 SPI, 3-Bit CRC Visual Basic ......63 ## SPI Communication Procedure Recommendations for the FXLS9xxxx ## **Contents** | 1 | Introduction | 4 | |----------|----------------------------------------------------------------------------------------------|------------| | 2 | Applicable Parts | | | 3 | | | | | Definition List | | | 4 | Further Assistance | | | 5 | References | | | 6 | Revision History | | | 7 | Apply Power to the FXLS9xxxx | | | 8 | Initialize and Configure the Devices | | | 8.1 | Complete a soft reset | | | 8.2 | Confirm device status | | | 8.3 | Configure SPI communication | 9 | | 8.4 | Optional complete register pattern write | | | | verification | | | 8.5 | Configure the data sources | | | 8.6 | Configure the sensor signal chain | | | 8.6.1 | Signal chain low pass filter selection | | | 8.6.2 | Signal chain user gain selection | 18 | | 8.6.3 | Signal chain data type configuration | 19 | | 8.7 | Complete startup coarse oscillator | | | | verification | 20 | | 8.8 | Confirm traceability information | 20 | | 8.9 | Optional read and record stored self-test | | | | data | 22 | | 8.10 | Confirm the device configuration | 23 | | 8.11 | Complete self-test (self-test overview) | | | 8.11.1 | Complete pre-self-test offset | | | 8.11.2 | Complete fixed value self-test | | | 8.11.3 | Complete digital self-test | | | 8.11.3.1 | | 31 | | 8.11.4 | Complete analog self-test | 31 | | 8.11.4.1 | | | | 8.11.5 | Restart offset cancellation fast startup | | | 8.12 | Transition to normal mode | | | 9 | Optional Continuous Oscillator Verification . | | | 10 | Optional User Diagnostics | | | 10.1 | Continuous railed output detection | | | 10.2 | Continuous sustained step detection | | | 10.3 | Normal Mode memory protection verification . | | | 11 | Bus Contention Considerations | | | 12 | Summary and Conclusion | | | 13 | Appendix | | | 13.1 | SPI state transition diagram | <b>5</b> 4 | | 13.2 | SPI startup error response timing | 55 | | 13.3 | Internal error response timing | | | 13.3.1 | Standard internal error conditions: transient | | | 13.3.1 | Standard internal error conditions: transient Standard internal error conditions: persistent | | | 13.3.2 | Apparent external error conditions: transient | | | 13.3.4 | Apparent external error conditions: | . 31 | | 10.0.4 | persistentpersistent persistent | 57 | | 13.3.5 | Supply errors: transient | | | 13.3.3 | Example SPI command list | | | 13.5 | CRC calculation examples | | | 13.5.1 | 8-bit CRC | | | 14 | Legai imormation | 64 | |--------|-------------------|-----| | 4.4 | Local information | C A | | 13.5.3 | 3-bit CRC | 63 | | 13.5.2 | 4-bit CRC | 62 | Please be aware that important notices concerning this document and the product(s) described herein, have been included in section 'Legal information'. © NXP B.V. 2021. All rights reserved.