

## ICM-20608-G Register Maps and Description Revision 1.0

InvenSense reserves the right to change the detail specifications as may be required to permit improvements in the design of its products. Document Number: RM-000030 Rev Number: 1.0 Rev Date: 06/15/2015

# InvenSense

| 1 | Purpo | ose and Scope                                                         | 3  |
|---|-------|-----------------------------------------------------------------------|----|
| 2 | Regis | ter Map                                                               | 4  |
| 3 | Regis | ter Descriptions                                                      | 6  |
|   | 3.1   | Registers 0 to 2 – Gyroscope Self-Test Registers                      | 6  |
|   | 3.2   | Registers 13 to 15 – Accelerometer Self-Test Registers                | 6  |
|   | 3.3   | Registers 19 – Gyro Offset Adjustment Register                        | 7  |
|   | 3.1   | Registers 20 – Gyro Offset Adjustment Register                        | 7  |
|   | 3.2   | Registers 21 – Gyro Offset Adjustment Register                        | 7  |
|   | 3.3   | Registers 22 – Gyro Offset Adjustment Register                        | 7  |
|   | 3.4   | Registers 23 – Gyro Offset Adjustment Register                        | 8  |
|   | 3.5   | Register 24 – Gyro Offset Adjustment Register                         | 8  |
|   | 3.6   | Register 25 – Sample Rate Divider                                     | 8  |
|   | 3.7   | Register 26 – Configuration                                           | 9  |
|   | 3.8   | Register 27 – Gyroscope Configuration                                 | 9  |
|   | 3.9   | Register 28 – Accelerometer Configuration                             | 10 |
|   | 3.10  | Register 29 – Accelerometer Configuration 2                           | 10 |
|   | 3.11  | Register 30 – Low Power Mode Configuration                            | 11 |
|   | 3.12  | Register 31 – Wake-on Motion Threshold (Accelerometer)                | 13 |
|   | 3.13  | Register 35 – FIFO Enable                                             | 14 |
|   | 3.14  | Register 54 – FSYNC Interrupt Status                                  | 14 |
|   | 3.15  | Register 55 – INT/DRDY Pin / Bypass Enable Configuration              | 14 |
|   | 3.16  | Register 56 – Interrupt Enable                                        | 15 |
|   | 3.17  | Register 58 – Interrupt Status                                        | 15 |
|   | 3.18  | Registers 59 to 64 – Accelerometer Measurements                       | 16 |
|   | 3.19  | Registers 65 and 66 – Temperature Measurement                         |    |
|   | 3.20  | Registers 67 to 72 – Gyroscope Measurements                           |    |
|   | 3.21  | Register 104 – Signal Path Reset                                      |    |
|   | 3.22  | Register 105 – Accelerometer Intelligence Control                     |    |
|   | 3.23  | Register 106 – User Control                                           |    |
|   | 3.24  | Register 107 – Power Management 1                                     |    |
|   | 3.25  | Register 108 – Power Management 2                                     | 20 |
|   | 3.26  | Register 114 and 115 – FIFO Count Registers                           | 20 |
|   | 3.27  | Register 116 – FIFO Read Write                                        |    |
|   | 3.28  | Register 117 – Who Am I                                               | 21 |
|   | 3.29  | Registers 119, 120, 122, 123, 125, 126 Accelerometer Offset Registers | 21 |
| 4 | Revis | ion History                                                           |    |



### **1** PURPOSE AND SCOPE

This document provides information regarding the register map and descriptions for the ICM-20608-G<sup>™</sup>. This document should be used in conjunction with the ICM-20608-G Product Specification (PS-ICM-20608-G-00) for detailed features, specifications, and other product information.

## 2 REGISTER MAP

#### The following table lists the register map for the ICM-20608-G.

| Addr<br>(Hex) | Addr<br>(Dec.) | Register Name     | Serial<br>I/F | Accessible<br>(writable) in<br>Sleep Mode | Bit7               | Bit6                 | Bit5             | Bit4                   | Bit3                | Bit2                      | Bit1          | BitO                |
|---------------|----------------|-------------------|---------------|-------------------------------------------|--------------------|----------------------|------------------|------------------------|---------------------|---------------------------|---------------|---------------------|
| 00            | 00             | SELF_TEST_X_GYRO  | R/W           | N                                         |                    | XG_ST_DATA[7:0]      |                  |                        |                     |                           |               |                     |
| 01            | 01             | SELF_TEST_Y_GYRO  | R/W           | N                                         |                    |                      |                  | YG_ST_                 | DATA[7:0]           |                           |               |                     |
| 02            | 02             | SELF_TEST_Z_GYRO  | R/W           | N                                         |                    |                      |                  | ZG_ST_                 | DATA[7:0]           |                           |               |                     |
| 0D            | 13             | SELF_TEST_X_ACCEL | R/W           | N                                         | XA_ST_DATA[7:0]    |                      |                  |                        |                     |                           |               |                     |
| OE            | 14             | SELF_TEST_Y_ACCEL | R/W           | N                                         |                    |                      |                  | YA_ST_                 | DATA[7:0]           |                           |               |                     |
| OF            | 15             | SELF_TEST_Z_ACCEL | R/W           | N                                         |                    |                      |                  | ZA_ST_                 | DATA[7:0]           |                           |               |                     |
| 13            | 19             | XG_OFFS_USRH      | R/W           | N                                         |                    |                      |                  | X_OFFS_                | USR [15:8]          |                           |               |                     |
| 14            | 20             | XG_OFFS_USRL      | R/W           | N                                         |                    |                      |                  | X_OFFS                 | _USR [7:0]          |                           |               |                     |
| 15            | 21             | YG_OFFS_USRH      | R/W           | N                                         |                    |                      |                  | Y_OFFS_                | USR [15:8]          |                           |               |                     |
| 16            | 22             | YG_OFFS_USRL      | R/W           | N                                         |                    |                      |                  | Y_OFFS                 | USR [7:0]           |                           |               |                     |
| 17            | 23             | ZG_OFFS_USRH      | R/W           | N                                         |                    |                      |                  | Z_OFFS_                | USR [15:8]          |                           |               |                     |
| 18            | 24             | ZG_OFFS_USRL      | R/W           | N                                         |                    |                      |                  | Z_OFFS                 | _USR [7:0]          |                           |               |                     |
| 19            | 25             | SMPLRT_DIV        | R/W           | N                                         |                    |                      |                  | SMPLR                  | [_DIV[7:0]          |                           |               |                     |
| 1A            | 26             | CONFIG            | R/W           | N                                         | -                  | FIFO_<br>MODE        | I                | EXT_SYNC_SET[2:0       | ]                   |                           | DLPF_CFG[2:0] |                     |
| 1B            | 27             | GYRO_CONFIG       | R/W           | N                                         | XG_ST              | YG_ST                | ZG_ST            | FS_SE                  | L [1:0]             | -                         | FCHOIC        | E_B[1:0]            |
| 1C            | 28             | ACCEL_CONFIG      | R/W           | N                                         | XA_ST              | YA_ST                | ZA_ST            | ACCEL_F                | 5_SEL[1:0]          |                           | -             |                     |
| 1D            | 29             | ACCEL_CONFIG 2    | R/W           | N                                         |                    | -                    | DEC2             | _CFG                   | ACCEL_FCHOI<br>CE_B |                           | A_DLPF_CFG    |                     |
| 1E            | 30             | LP_MODE_CFG       | R/W           | N                                         | GYRO_CYCL<br>E     |                      | G_AVGCFG[2:0]    |                        | -                   |                           | LPOSC_CLKSEL  |                     |
| 1F            | 31             | ACCEL_WOM_THR     | R/W           | N                                         | WOM_THR[7:0]       |                      |                  |                        |                     |                           |               |                     |
| 23            | 35             | FIFO_EN           | R/W           | N                                         | TEMP<br>_FIFO_EN   | XG_FIFO_EN           | YG_FIFO_EN       | ZG_FIFO_EN             | ACCEL_FIFO_<br>EN   | -                         | -             | -                   |
| 36            | 54             | FSYNC_INT         | R/C           | N                                         | FSYNC_INT          | -                    | -                | -                      | -                   | -                         | -             | -                   |
| 37            | 55             | INT_PIN_CFG       | R/W           | Y                                         | INT_LEVEL          | INT_OPEN             | LATCH<br>_INT_EN | INT_RD<br>_CLEAR       | FSYNC_INT_L<br>EVEL | FSYNC<br>_INT_MODE_<br>EN | -             | -                   |
| 38            | 56             | INT_ENABLE        | R/W           | Y                                         |                    | WOM_INT_EN[7:5       | 5]               | FIFO<br>_OFLOW<br>_EN  | -                   | GDRIVE_INT_<br>EN         | -             | DATA_RDY_I<br>NT_EN |
| 3A            | 58             | INT_STATUS        | R/C           | N                                         |                    | WOM_INT[7:5]         |                  | FIFO<br>_OFLOW<br>_INT | -                   | GDRIVE_INT                | -             | DATA<br>_RDY_INT    |
| 3B            | 59             | ACCEL_XOUT_H      | R             | N                                         |                    |                      |                  | ACCEL_XC               | DUT_H[15:8]         |                           |               |                     |
| 3C            | 60             | ACCEL_XOUT_L      | R             | N                                         |                    |                      |                  | ACCEL_X                | OUT_L[7:0]          |                           |               |                     |
| 3D            | 61             | ACCEL_YOUT_H      | R             | N                                         |                    |                      |                  | ACCEL_YC               | OUT_H[15:8]         |                           |               |                     |
| 3E            | 62             | ACCEL_YOUT_L      | R             | N                                         |                    |                      |                  | ACCEL_Y                | OUT_L[7:0]          |                           |               |                     |
| 3F            | 63             | ACCEL_ZOUT_H      | R             | N                                         |                    |                      |                  | ACCEL_ZC               | OUT_H[15:8]         |                           |               |                     |
| 40            | 64             | ACCEL_ZOUT_L      | R             | N                                         |                    |                      |                  | ACCEL_Z                | OUT_L[7:0]          |                           |               |                     |
| 41            | 65             | TEMP_OUT_H        | R             | N                                         |                    |                      |                  | TEMP_0                 | OUT[15:8]           |                           |               |                     |
| 42            | 66             | TEMP_OUT_L        | R             | N                                         |                    |                      |                  | TEMP                   | OUT[7:0]            |                           |               |                     |
| 43            | 67             | GYRO_XOUT_H       | R             | N                                         |                    |                      |                  |                        | OUT[15:8]           |                           |               |                     |
| 44            | 68             | GYRO_XOUT_L       | R             | N                                         |                    |                      |                  |                        | KOUT[7:0]           |                           |               |                     |
| 45            | 69             | GYRO_YOUT_H       | R             | N                                         |                    |                      |                  |                        | OUT[15:8]           |                           |               |                     |
| 46            | 70             | GYRO_YOUT_L       | R             | N                                         |                    |                      |                  |                        | /OUT[7:0]           |                           |               |                     |
| 47            | 71             | GYRO_ZOUT_H       | R             | N                                         |                    |                      |                  |                        | OUT[15:8]           |                           |               |                     |
| 48            | 72             | GYRO_ZOUT_L       | R             | N                                         |                    |                      |                  |                        | ZOUT[7:0]           |                           |               |                     |
| 68            | 104            | SIGNAL_PATH_RESET | R/W           | N                                         | -                  | -                    | -                | -                      | -                   | -                         | ACCEL<br>_RST | TEMP<br>_RST        |
| 69            | 105            | ACCEL_INTEL_CTRL  | R/W           | N                                         | ACCEL_INTE<br>L_EN | ACCEL_INTEL<br>_MODE |                  | ·                      | ·                   | -                         |               | •                   |
| 6A            | 106            | USER_CTRL         | R/W           | N                                         | -                  | FIFO_EN              | -                | I2C_IF<br>_DIS         | -                   | FIFO<br>_RST              | -             | SIG_COND<br>_RST    |
| 6B            | 107            | PWR_MGMT_1        | R/W           | Y                                         | DEVICE_RES<br>ET   | SLEEP                | ACCEL_CYCLE      | GYRO_<br>STANDBY       | TEMP_DIS            |                           | CLKSEL[2:0]   |                     |





| Addr<br>(Hex) | Addr<br>(Dec.) | Register Name | Serial<br>I/F | Accessible<br>(writable) in<br>Sleep Mode | Bit7           | Bit6 | Bit5    | Bit4          | Bit3      | Bit2             | Bit1    | Bit0    |
|---------------|----------------|---------------|---------------|-------------------------------------------|----------------|------|---------|---------------|-----------|------------------|---------|---------|
| 6C            | 108            | PWR_MGMT_2    | R/W           | Y                                         | FIFO_LP_EN     | -    | STBY_XA | STBY_YA       | STBY_ZA   | STBY_XG          | STBY_YG | STBY_ZG |
| 72            | 114            | FIFO_COUNTH   | R             | N                                         |                | -    |         |               |           | FIFO_COUNT[12:8] | ]       |         |
| 73            | 115            | FIFO_COUNTL   | R             | N                                         |                |      |         | FIFO_CO       | DUNT[7:0] |                  |         |         |
| 74            | 116            | FIFO_R_W      | R/W           | N                                         |                |      |         | FIFO_D        | ATA[7:0]  |                  |         |         |
| 75            | 117            | WHO_AM_I      | R             | N                                         |                |      |         | WHO/          | AMI[7:0]  |                  |         |         |
| 77            | 119            | XA_OFFSET_H   | R/W           | N                                         |                |      |         | XA_OF         | FS [14:7] |                  |         |         |
| 78            | 120            | XA_OFFSET_L   | R/W           | N                                         |                |      |         | XA_OFFS [6:0] |           |                  |         | -       |
| 7A            | 122            | YA_OFFSET_H   | R/W           | N                                         |                |      |         | YA_OF         | FS [14:7] |                  |         |         |
| 7B            | 123            | YA_OFFSET_L   | R/W           | N                                         |                |      |         | YA_OFFS [6:0] |           |                  |         | -       |
| 7D            | 125            | ZA_OFFSET_H   | R/W           | N                                         | ZA_OFFS [14:7] |      |         |               |           |                  |         |         |
| 7E            | 126            | ZA_OFFSET_L   | R/W           | N                                         |                |      |         | ZA_OFFS [6:0] |           |                  |         | -       |

<u>Note:</u> Register Names ending in \_H and \_L contain the high and low bytes, respectively, of an internal register value.

In the detailed register tables that follow, register names are in capital letters, while register values are in capital letters and italicized. For example, the ACCEL\_XOUT\_H register (Register 59) contains the 8 most significant bits, ACCEL\_XOUT[15:8], of the 16-bit X-Axis accelerometer measurement, ACCEL\_XOUT.

The reset value is 0x00 for all registers other than the registers below, also the self-test registers contain pre-programmed values and will not be 0x00 after reset.

- Register 107 (0x40) Power Management 1
- Register 117 (0xAF) WHO\_AM\_I

## **3** REGISTER DESCRIPTIONS

This section describes the function and contents of each register within the ICM-20608-G. <u>Note:</u> The device will come up in sleep mode upon power-up.

#### 3.1 **REGISTERS 0 TO 2 – GYROSCOPE SELF-TEST REGISTERS**

### Register Name: SELF\_TEST\_X\_GYRO, SELF\_TEST\_Y\_GYRO, SELF\_TEST\_Z\_GYRO

Type: READ/WRITE

Register Address: 00, 01, 02 (Decimal); 00, 01, 02 (Hex)

| REGISTER         | BIT   | NAME            | FUNCTION                                                            |
|------------------|-------|-----------------|---------------------------------------------------------------------|
|                  |       |                 | The value in this register indicates the self-test output generated |
| SELF_TEST_X_GYRO | [7:0] | XG_ST_DATA[7:0] | during manufacturing tests. This value is to be used to check       |
|                  |       |                 | against subsequent self-test outputs performed by the end user.     |
|                  |       |                 | The value in this register indicates the self-test output generated |
| SELF_TEST_Y_GYRO | [7:0] | YG_ST_DATA[7:0] | during manufacturing tests. This value is to be used to check       |
|                  |       |                 | against subsequent self-test outputs performed by the end user.     |
|                  |       |                 | The value in this register indicates the self-test output generated |
| SELF_TEST_Z_GYRO | [7:0] | ZG_ST_DATA[7:0] | during manufacturing tests. This value is to be used to check       |
|                  |       |                 | against subsequent self-test outputs performed by the end user.     |

The equation to convert self-test codes in OTP to factory self-test measurement is:

$$ST \_OTP = (2620/2^{FS}) * 1.01^{(ST\_code=1)}$$
 (lsb)

where ST\_OTP is the value that is stored in OTP of the device, FS is the Full Scale value, and ST\_code is based on the Self-Test value (ST\_FAC) determined in InvenSense's factory final test and calculated based on the following equation:

$$ST\_code = round(\frac{\log(ST\_FAC/(2620/2^{FS}))}{\log(1.01)}) + 1$$

#### 3.2 REGISTERS 13 TO 15 – ACCELEROMETER SELF-TEST REGISTERS

Register Name: SELF\_TEST\_X\_ACCEL, SELF\_TEST\_Y\_ACCEL, SELF\_TEST\_Z\_ACCEL Type: READ/WRITE

Register Address: 13, 14, 15 (Decimal); 0D, 0E, 0F (Hex)

| REGISTER          | BITS  | NAME            | FUNCTION                                                                                                                                                                                                   |  |  |  |  |
|-------------------|-------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| SELF_TEST_X_ACCEL | [7:0] | XA_ST_DATA[7:0] | The value in this register indicates the self-test output<br>generated during manufacturing tests. This value is to be used<br>to check against subsequent self-test outputs performed by the<br>end user. |  |  |  |  |
| SELF_TEST_Y_ACCEL | [7:0] | YA_ST_DATA[7:0] | The value in this register indicates the self-test output<br>generated during manufacturing tests. This value is to be used<br>to check against subsequent self-test outputs performed by the<br>end user. |  |  |  |  |
| SELF_TEST_Z_ACCEL | [7:0] | ZA_ST_DATA[7:0] | The value in this register indicates the self-test output<br>generated during manufacturing tests. This value is to be used<br>to check against subsequent self-test outputs performed by the<br>end user. |  |  |  |  |

The equation to convert self-test codes in OTP to factory self-test measurement is:



### $ST \_OTP = (2620/2^{FS}) * 1.01^{(ST\_code=1)}$ (lsb)

where ST\_OTP is the value that is stored in OTP of the device, FS is the Full Scale value, and ST\_code is based on the Self-Test value (ST\_FAC) determined in InvenSense's factory final test and calculated based on the following equation:

$$ST\_code = round(\frac{\log(ST\_FAC/(2620/2^{FS}))}{\log(1.01)}) + 1$$

#### 3.3 REGISTERS 19 – GYRO OFFSET ADJUSTMENT REGISTER

Register Name: XG\_OFFS\_USRH Register Type: READ/WRITE Register Address: 19 (Decimal); 13 (Hex)

| BIT   | NAME             | FUNCTION                                                                                                                                                                                                                                    |
|-------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | X_OFFS_USR[15:8] | Bits 15 to 8 of the 16-bit offset of X gyroscope (2's complement). This register is used to remove DC bias from the sensor output. The value in this register is added to the gyroscope sensor value before going into the sensor register. |

#### 3.1 **REGISTERS 20 – GYRO OFFSET ADJUSTMENT REGISTER**

Register Name: XG\_OFFS\_USRL Register Type: READ/WRITE Register Address: 20 (Decimal); 14 (Hex)

| BIT   | NAME            | FUNCTION                                                                                                                                                                                                                                   |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | X_OFFS_USR[7:0] | Bits 7 to 0 of the 16-bit offset of X gyroscope (2's complement). This register is used to remove DC bias from the sensor output. The value in this register is added to the gyroscope sensor value before going into the sensor register. |

#### 3.2 **REGISTERS 21 – GYRO OFFSET ADJUSTMENT REGISTER**

Register Name: YG\_OFFS\_USRH Register Type: READ/WRITE Register Address: 21 (Decimal); 15 (Hex)

| BIT   | NAME             | FUNCTION                                                                                                                                                                                                                                    |
|-------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | Y_OFFS_USR[15:8] | Bits 15 to 8 of the 16-bit offset of Y gyroscope (2's complement). This register is used to remove DC bias from the sensor output. The value in this register is added to the gyroscope sensor value before going into the sensor register. |

#### 3.3 **REGISTERS 22 – GYRO OFFSET ADJUSTMENT REGISTER**

Register Name: YG\_OFFS\_USRL Register Type: READ/WRITE Register Address: 22 (Decimal); 16 (Hex)



## ICM-20608-G

| BIT   | NAME            | FUNCTION                                                                                                                                                                                                                                   |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | Y_OFFS_USR[7:0] | Bits 7 to 0 of the 16-bit offset of Y gyroscope (2's complement). This register is used to remove DC bias from the sensor output. The value in this register is added to the gyroscope sensor value before going into the sensor register. |

#### 3.4 REGISTERS 23 – GYRO OFFSET ADJUSTMENT REGISTER

Register Name: ZG\_OFFS\_USRH Register Type: READ/WRITE Register Address: 23 (Decimal); 17 (Hex)

| BIT   | NAME             | FUNCTION                                                                                                                                                                                                                                    |
|-------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | Z_OFFS_USR[15:8] | Bits 15 to 8 of the 16-bit offset of Z gyroscope (2's complement). This register is used to remove DC bias from the sensor output. The value in this register is added to the gyroscope sensor value before going into the sensor register. |

#### 3.5 **REGISTER 24 – GYRO OFFSET ADJUSTMENT REGISTER**

Register Name: ZG\_OFFS\_USRL Register Type: READ/WRITE Register Address: 24 (Decimal); 18 (Hex)

| BIT   | NAME            | FUNCTION                                                                                                                                                                                                                                   |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | Z_OFFS_USR[7:0] | Bits 7 to 0 of the 16-bit offset of Z gyroscope (2's complement). This register is used to remove DC bias from the sensor output. The value in this register is added to the gyroscope sensor value before going into the sensor register. |

#### 3.6 **REGISTER 25 – SAMPLE RATE DIVIDER**

Register Name: SMPLRT\_DIV Register Type: READ/WRITE Register Address: 25 (Decimal); 19 (Hex)

| BIT   | NAME            | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | SMPLRT_DIV[7:0] | Divides the internal sample rate (see register CONFIG) to generate the sample<br>rate that controls sensor data output rate, FIFO sample rate. NOTE: This register<br>is only effective when FCHOICE_B register bits are 2'b00, and (0 < DLPF_CFG < 7).<br>This is the update rate of the sensor register:<br>SAMPLE_RATE = INTERNAL_SAMPLE_RATE / (1 + SMPLRT_DIV)<br>Where INTERNAL_SAMPLE_RATE = 1kHz |



#### 3.7 **REGISTER 26 – CONFIGURATION**

Register Name: CONFIG Register Type: READ/WRITE Register Address: 26 (Decimal); 1A (Hex)

| BIT   | NAME              | FUNCTION                                                                               | FUNCTION                                                                               |                               |                 |  |  |  |
|-------|-------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------|-----------------|--|--|--|
| [7]   | -                 | Always set to 0                                                                        | Always set to 0                                                                        |                               |                 |  |  |  |
| [6]   | FIFO_MODE         | When set to '1', w                                                                     | When set to '1', when the FIFO is full, additional writes will not be written to FIFO. |                               |                 |  |  |  |
|       |                   | When set to '0', w                                                                     | when the FIFO is full, ad                                                              | ditional writes will be writt | en to the FIFO, |  |  |  |
|       |                   | replacing the olde                                                                     | est data.                                                                              |                               |                 |  |  |  |
| [5:3] | EXT_SYNC_SET[2:0] | Enables the FSYN                                                                       | C pin data to be sample                                                                | ed.                           |                 |  |  |  |
|       |                   |                                                                                        |                                                                                        |                               |                 |  |  |  |
|       |                   |                                                                                        | EXT_SYNC_SET                                                                           | FSYNC bit location            |                 |  |  |  |
|       |                   |                                                                                        | 0 function disabled                                                                    |                               |                 |  |  |  |
|       |                   | 1 TEMP_OUT_L[0]                                                                        |                                                                                        |                               |                 |  |  |  |
|       |                   | 2 GYRO_XOUT_L[0]                                                                       |                                                                                        |                               |                 |  |  |  |
|       |                   |                                                                                        | 3                                                                                      | GYRO_YOUT_L[0]                |                 |  |  |  |
|       |                   |                                                                                        | 4                                                                                      | GYRO_ZOUT_L[0]                |                 |  |  |  |
|       |                   |                                                                                        | 5                                                                                      | ACCEL_XOUT_L[0]               |                 |  |  |  |
|       |                   |                                                                                        | 6                                                                                      | ACCEL_YOUT_L[0]               |                 |  |  |  |
|       |                   | 7 ACCEL_ZOUT_L[0]                                                                      |                                                                                        |                               |                 |  |  |  |
|       |                   | FSYNC will be latched to capture short strobes. This will be done such that if FSYNC   |                                                                                        |                               |                 |  |  |  |
|       |                   | toggles, the latched value toggles, but won't toggle again until the new latched value |                                                                                        |                               |                 |  |  |  |
|       |                   | is captured by the sample rate strobe.                                                 |                                                                                        |                               |                 |  |  |  |
| [2:0] | DLPF_CFG[2:0]     | For the DLPF to b                                                                      | e used, FCHOICE_B[1:0]                                                                 | ] is 2'b00.                   |                 |  |  |  |
|       |                   | See the table belo                                                                     | ow.                                                                                    |                               |                 |  |  |  |

The DLPF is configured by  $DLPF\_CFG$ , when  $FCHOICE\_B$  [1:0] = 2b'00. The gyroscope and temperature sensor are filtered according to the value of  $DLPF\_CFG$  and  $FCHOICE\_B$  as shown in the table below.

| FCHO | FCHOICE_B |          | Gyroscope       |                  |               | Temperature<br>Sensor |
|------|-----------|----------|-----------------|------------------|---------------|-----------------------|
| <1>  | <0>       | DLPF_CFG | 3-dB BW<br>(Hz) | Noise BW<br>(Hz) | Rate<br>(kHz) | 3-dB BW (Hz)          |
| Х    | 1         | Х        | 8173            | 8595.1           | 32            | 4000                  |
| 1    | 0         | х        | 3281            | 3451.0           | 32            | 4000                  |
| 0    | 0         | 0        | 250             | 306.6            | 8             | 4000                  |
| 0    | 0         | 1        | 176             | 177.0            | 1             | 188                   |
| 0    | 0         | 2        | 92              | 108.6            | 1             | 98                    |
| 0    | 0         | 3        | 41              | 59.0             | 1             | 42                    |
| 0    | 0         | 4        | 20              | 30.5             | 1             | 20                    |
| 0    | 0         | 5        | 10              | 15.6             | 1             | 10                    |
| 0    | 0         | 6        | 5               | 8.0              | 1             | 5                     |
| 0    | 0         | 7        | 3281            | 3451.0           | 8             | 4000                  |

#### 3.8 **REGISTER 27 – GYROSCOPE CONFIGURATION**

Register Name: GYRO\_CONFIG Register Type: READ/WRITE Register Address: 27 (Decimal); 1B (Hex)

| BIT | NAME  | FUNCTION         |
|-----|-------|------------------|
| [7] | XG_ST | X Gyro self-test |



| [6]   | YG_ST          | Y Gyro self-test                               |
|-------|----------------|------------------------------------------------|
| [5]   | ZG_ST          | Z Gyro self-test                               |
|       |                | Gyro Full Scale Select:                        |
|       |                | 00 = ±250dps                                   |
| [4:3] | FS_SEL[1:0]    | 01= ±500dps                                    |
|       |                | 10 = ±1000dps                                  |
|       |                | 11 = ±2000dps                                  |
| [2]   | -              | Reserved                                       |
| [1:0] | FCHOICE_B[1:0] | Used to bypass DLPF as shown in table 1 above. |

#### 3.9 REGISTER 28 – ACCELEROMETER CONFIGURATION

Register Name: ACCEL\_CONFIG Register Type: READ/WRITE Register Address: 28 (Decimal); 1C (Hex)

| BIT   | NAME              | FUNCTION                                |  |  |  |
|-------|-------------------|-----------------------------------------|--|--|--|
| [7]   | XA_ST             | X Accel self-test                       |  |  |  |
| [6]   | YA_ST             | Y Accel self-test                       |  |  |  |
| [5]   | ZA_ST             | Z Accel self-test                       |  |  |  |
| [4:3] | ACCEL FS SEL[1:0] | Accel Full Scale Select:                |  |  |  |
| [4.5] | ACCEL_13_SEC[1.0] | ±2g (00), ±4g (01), ±8g (10), ±16g (11) |  |  |  |
| [2:0] | -                 | Reserved                                |  |  |  |

#### 3.10 REGISTER 29 – ACCELEROMETER CONFIGURATION 2

Register Name: ACCEL\_CONFIG2 Register Type: READ/WRITE Register Address: 29 (Decimal); 1D (Hex)

| BIT   | NAME            | FUNCTION                                                                                                                                                          |
|-------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6] | -               | Reserved                                                                                                                                                          |
| [5:4] | DEC2_CFG[1:0]   | Averaging filter settings for Low Power Accelerometer mode:<br>0 = Average 4 samples<br>1 = Average 8 samples<br>2 = Average 16 samples<br>3 = Average 32 samples |
| [3]   | ACCEL_FCHOICE_B | Used to bypass DLPF as shown in the table below.                                                                                                                  |
| [2:0] | A_DLPF_CFG      | Accelerometer low pass filter setting as shown in the table below.                                                                                                |

|                 |            |                 |                  | ſ             |
|-----------------|------------|-----------------|------------------|---------------|
| ACCEL_FCHOICE_B | A_DLPF_CFG | 3-dB BW<br>(Hz) | Noise BW<br>(Hz) | Rate<br>(kHz) |
| 1               | Х          | 1046.0          | 1100.0           | 4             |
| 0               | 0          | 218.1           | 235.0            | 1             |
| 0               | 1          | 218.1           | 235.0            | 1             |
| 0               | 2          | 99.0            | 121.3            | 1             |
| 0               | 3          | 44.8            | 61.5             | 1             |
| 0               | 4          | 21.2            | 31.0             | 1             |
| 0               | 5          | 10.2            | 15.5             | 1             |
| 0               | 6          | 5.1             | 7.8              | 1             |
| 0               | 7          | 420.0           | 441.6            | 1             |

#### Accelerometer Data Rates and Bandwidths (Low-Noise Mode)

The data output rate of the DLPF filter block can be further reduced by a factor of 1/(1+SMPLRT\_DIV), where SMPLRT\_DIV is an 8-bit integer. Following is a small subset of ODRs that are configurable for the accelerometer in the low-noise mode in this manner (Hz): 3.91, 7.81, 15.63, 31.25, 62.50, 125, 250, 500, 1K.

The following table lists the accelerometer filter bandwidths, noise, and current consumption available in the low-power mode of operation. In the low-power mode of operation, the accelerometer is duty-cycled.

| -                         |             |                              |       |       |       |       |
|---------------------------|-------------|------------------------------|-------|-------|-------|-------|
| ACCEL_FCHC                | DICE_B      | 1                            | 0     | 0     | 0     | 0     |
| A_DLPF_C                  | CFG         | х                            | 7     | 7     | 7     | 7     |
| DEC2_CF                   | G           | х                            | 0     | 1     | 2     | 3     |
| Average                   | 2S          | 1x                           | 4x    | 8x    | 16x   | 32x   |
| Ton (ms                   | 5)          | 1.084                        | 1.84  | 2.84  | 4.84  | 8.84  |
| Noise BW                  | (Hz)        | 1100.0                       | 441.6 | 235.4 | 121.3 | 61.5  |
| Noise (mg) TYP<br>250µg/√ |             | 8.3                          | 5.3   | 3.8   | 2.8   | 2.0   |
| SMPLRT_DIV                | ODR<br>(Hz) | Current Consumption (µA) TYP |       |       |       |       |
| 255                       | 3.9         | 8.4                          | 9.4   | 10.8  | 13.6  | 19.2  |
| 127                       | 7.8         | 9.8                          | 11.9  | 14.7  | 20.3  | 31.4  |
| 63                        | 15.6        | 12.8                         | 17.0  | 22.5  | 33.7  | 55.9  |
| 31                        | 31.3        | 18.7                         | 27.1  | 38.2  | 60.4  | 104.9 |
| 15                        | 62.5        | 30.4                         | 47.2  | 69.4  | 113.9 | 202.8 |
| 7                         | 125.0       | 57.4                         | 87.5  | 132.0 | 220.9 | N/A   |
| 3                         | 250.0       | 100.9 168.1 257.0 N/A        |       |       |       | /A    |
| 1                         | 500.0       | 194.9                        | 329.3 |       | N/A   |       |

#### 3.11 REGISTER 30 – LOW POWER MODE CONFIGURATION

#### Register Name: LP\_MODE\_CFG Register Type: READ/WRITE Register Address: 30 (Decimal); 1E (Hex)

| BIT   | NAME          | FUNCTION                                                                                 |
|-------|---------------|------------------------------------------------------------------------------------------|
| [7]   | GYRO_CYCLE    | When set to '1' low-power gyroscope mode is enabled. Default setting is '0'              |
| [6:4] | G_AVGCFG[2:0] | Averaging filter configuration for low-power gyroscope mode.<br>Default setting is '000' |



## ICM-20608-G

|       |              |  | ency of waking up<br>power accel Outp | the chip to take a san<br>ut Data Rate | ple of accel |
|-------|--------------|--|---------------------------------------|----------------------------------------|--------------|
|       |              |  | LPOSC_CLKSEL                          |                                        |              |
|       |              |  | 0                                     | 0.24                                   |              |
|       |              |  | 1                                     | 0.49                                   |              |
|       |              |  | 2                                     | 0.98                                   |              |
|       |              |  | 3                                     | 1.95                                   |              |
| [3:0] | LPOSC CLKSEL |  | 4                                     | 3.91                                   |              |
| [5:0] | LPUSC_CLKSEL |  | 5                                     | 7.81                                   |              |
|       |              |  | 6                                     | 15.63                                  |              |
|       |              |  | 7                                     | 31.25                                  |              |
|       |              |  | 8                                     | 62.50                                  |              |
|       |              |  | 9                                     | 125                                    |              |
|       |              |  | 10                                    | 250                                    |              |
|       |              |  | 11                                    | 500                                    |              |
|       |              |  | 12-15                                 | Reserved                               |              |

To operate in gyroscope low-power mode or 6-axis low-power mode, GYRO\_CYCLE should be set to '1.' Gyroscope filter configuration is determined by G\_AVGCFG[2:0] that sets the averaging filter configuration. It is not dependent on DLPF\_CFG[2:0]. The following table shows some example configurations for gyroscope low power mode.

| FCHOICE                                   | B           | 0                            | 0     | 0     | 0     | 0       | 0     | 0     | 0     |
|-------------------------------------------|-------------|------------------------------|-------|-------|-------|---------|-------|-------|-------|
| G_AVGC                                    | FG          | 0                            | 1     | 2     | 3     | 4       | 5     | 6     | 7     |
| Average                                   | es          | 1x                           | 2x    | 4x    | 8x    | 16x     | 32x   | 64x   | 128x  |
| Ton (ms                                   | 5)          | 1.73                         | 2.23  | 3.23  | 5.23  | 9.23    | 17.23 | 33.23 | 65.23 |
| Noise BW                                  | (Hz)        | 650.8                        | 407.1 | 224.2 | 117.4 | 60.2    | 30.6  | 15.6  | 8.0   |
| Noise (dps) TYP<br>0.008º/s/ <sup>-</sup> |             | 0.20                         | 0.16  | 0.12  | 0.09  | 0.06    | 0.04  | 0.03  | 0.02  |
| SMPLRT_DIV                                | ODR<br>(Hz) | Current Consumption (mA) TYP |       |       |       |         |       |       |       |
| 255                                       | 3.9         | 1.3                          | 1.3   | 1.3   | 1.3   | 1.4     | 1.4   | 1.5   | 1.8   |
| 99                                        | 10.0        | 1.3                          | 1.3   | 1.4   | 1.4   | 1.5     | 1.6   | 1.9   | 2.5   |
| 64                                        | 15.4        | 1.4                          | 1.4   | 1.4   | 1.5   | 1.6     | 1.8   | 2.2   | N/A   |
| 32                                        | 30.3        | 1.4                          | 1.4   | 1.5   | 1.6   | 1.8     | 2.2   | N/    | /^    |
| 19                                        | 50.0        | 1.5                          | 1.5   | 1.6   | 1.8   | 2.1     | 2.8   | IN/   | A     |
| 9                                         | 100.0       | 1.6                          | 1.7   | 1.9   | 2.2   | 3.0     |       | N/A   |       |
| 7                                         | 125.0       | 1.7                          | 1.8   | 2.0   | 2.5   | 2.5 N/A |       |       |       |
| 4                                         | 200.0       | 1.9                          | 2.1   | 2.5   | N/A   |         |       |       |       |
| 3                                         | 250.0       | 2.1                          | 2.3   | 2.7   | N/A   |         |       |       |       |
| 2                                         | 333.3       | 2.3                          | 2.6   |       | N/A   |         |       |       |       |
| 1                                         | 500.0       | 2.9                          |       |       | N/A   |         |       |       |       |

#### 3.12 REGISTER 31 – WAKE-ON MOTION THRESHOLD (ACCELEROMETER)

#### Register Name: ACCEL\_WOM\_THR Register Type: READ/WRITE Register Address: 31 (Decimal); 1F (Hex)

| BIT   | NAME         | FUNCTION                                                                                    |  |  |  |  |
|-------|--------------|---------------------------------------------------------------------------------------------|--|--|--|--|
| [7:0] | WOM_THR[7:0] | This register holds the threshold value for the Wake on Motion Interrupt for accelerometer. |  |  |  |  |

#### 3.13 **REGISTER 35 – FIFO ENABLE**

| Register Name: FIFO_EN                   |
|------------------------------------------|
| Register Type: READ/WRITE                |
| Register Address: 35 (Decimal); 23 (Hex) |

| BIT   | NAME          | FUNCTION                                                                   |
|-------|---------------|----------------------------------------------------------------------------|
|       |               | 1 – Write TEMP_OUT_H and TEMP_OUT_L to the FIFO at the sample rate; If     |
| [7]   | TEMP_FIFO_EN  | enabled, buffering of data occurs even if data path is in standby.         |
|       |               | 0 – function is disabled                                                   |
|       |               | 1 – Write GYRO_XOUT_H and GYRO_XOUT_L to the FIFO at the sample rate; If   |
| [6]   | XG_FIFO_EN    | enabled, buffering of data occurs even if data path is in standby.         |
|       |               | 0 – function is disabled                                                   |
|       |               | 1 – Write GYRO_YOUT_H and GYRO_YOUT_L to the FIFO at the sample rate; If   |
|       |               | enabled, buffering of data occurs even if data path is in standby.         |
| [5]   | YG FIFO EN    | 0 – function is disabled                                                   |
| [3]   |               | NOTE: Enabling any one of the bits corresponding to the Gyros or Temp data |
|       |               | paths, data is buffered into the FIFO even though that data path is not    |
|       |               | enabled.                                                                   |
|       |               | 1 – Write GYRO_ZOUT_H and GYRO_ZOUT_L to the FIFO at the sample rate; If   |
| [4]   | ZG_FIFO_EN    | enabled, buffering of data occurs even if data path is in standby.         |
|       |               | 0 – function is disabled                                                   |
|       |               | 1 – write ACCEL_XOUT_H, ACCEL_XOUT_L, ACCEL_YOUT_H, ACCEL_YOUT_L,          |
| [3]   | ACCEL_FIFO_EN | ACCEL_ZOUT_H, and ACCEL_ZOUT_L to the FIFO at the sample rate;             |
|       |               | 0 – function is disabled                                                   |
| [2:0] | -             | Reserved                                                                   |

#### 3.14 REGISTER 54 – FSYNC INTERRUPT STATUS

#### Register Name: FSYNC\_INT Register Type: READ to CLEAR Register Address: 54 (Decimal); 36 (Hex)

| BIT | NAME      | FUNCTION                                                                    |
|-----|-----------|-----------------------------------------------------------------------------|
| [7] | FSYNC INT | This bit automatically sets to 1 when a FSYNC interrupt has been generated. |
| [/] |           | The bit clears to 0 after the register has been read.                       |

#### 3.15 REGISTER 55 – INT/DRDY PIN / BYPASS ENABLE CONFIGURATION

Register Name: INT\_PIN\_CFG Register Type: READ/WRITE Register Address: 55 (Decimal); 37 (Hex)

| BIT | NAME            | FUNCTION                                                              |
|-----|-----------------|-----------------------------------------------------------------------|
| [7] | INT LEVEL       | 1 – The logic level for INT/DRDY pin is active low.                   |
| [7] |                 | 0 – The logic level for INT/DRDY pin is active high.                  |
| [6] |                 | 1 – INT/DRDY pin is configured as open drain.                         |
| [6] | INT_OPEN        | 0 – INT/DRDY pin is configured as push-pull.                          |
| (61 |                 | 1 – INT/DRDY pin level held until interrupt status is cleared.        |
| [5] | LATCH_INT_EN    | 0 – INT/DRDY pin indicates interrupt pulse's width is 50us.           |
| [4] |                 | 1 – Interrupt status is cleared if any read operation is performed.   |
| [4] | INT_RD_CLEAR    | 0 – Interrupt status is cleared only by reading INT_STATUS register   |
| [2] | FSYNC_INT_LEVEL | 1 – The logic level for the FSYNC pin as an interrupt is active low.  |
| [3] |                 | 0 – The logic level for the FSYNC pin as an interrupt is active high. |



| BIT | NAME              | FUNCTION                                                                                                                                                                                                              |
|-----|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | FSYNC_INT_MODE_EN | When this bit is equal to 1, the FSYNC pin will trigger an interrupt when it transitions to the level specified by FSYNC_INT_LEVEL. When this bit is equal to 0, the FSYNC pin is disabled from causing an interrupt. |
| [1] | -                 | Reserved                                                                                                                                                                                                              |
| [0] | -                 | Always set to 0                                                                                                                                                                                                       |

#### 3.16 REGISTER 56 – INTERRUPT ENABLE

#### Register Name: INT\_ENABLE Register Type: READ/WRITE Register Address: 56 (Decimal); 38 (Hex)

| BIT   | NAME            | FUNCTION                                                                                                            |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------|
| [7:5] | WOM_INT_EN[7:5] | 111 – Enable WoM interrupt on accelerometer.<br>000 – Disable WoM interrupt on accelerometer.                       |
| [4]   | FIFO_OFLOW_EN   | <ul> <li>1 – Enables a FIFO buffer overflow to generate an interrupt.</li> <li>0 – Function is disabled.</li> </ul> |
| [3]   | -               | Reserved                                                                                                            |
| [2]   | GDRIVE_INT_EN   | Gyroscope Drive System Ready interrupt enable                                                                       |
| [1]   | -               | Reserved                                                                                                            |
| [0]   | DATA_RDY_INT_EN | Data ready interrupt enable                                                                                         |

#### 3.17 REGISTER 58 – INTERRUPT STATUS

#### Register Name: INT\_STATUS Register Type: READ to CLEAR Register Address: 58 (Decimal); 3A (Hex)

| BIT   | NAME           | FUNCTION                                                                                                                               |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------|
| [7:5] | WOM_INT        | Accelerometer WoM interrupt status. Cleared on Read.<br>111 – WoM interrupt on accelerometer                                           |
| [4]   | FIFO_OFLOW_INT | This bit automatically sets to 1 when a FIFO buffer overflow has been generated. The bit clears to 0 after the register has been read. |
| [3]   | -              | Reserved.                                                                                                                              |
| [2]   | GDRIVE_INT     | Gyroscope Drive System Ready interrupt                                                                                                 |
| [1]   | -              | Reserved.                                                                                                                              |
| [0]   | DATA_RDY_INT   | This bit automatically sets to 1 when a Data Ready interrupt is generated. The bit clears to 0 after the register has been read.       |



#### 3.18 REGISTERS 59 TO 64 – ACCELEROMETER MEASUREMENTS

Register Name: ACCEL\_XOUT\_H Register Type: READ only Register Address: 59 (Decimal); 3B (Hex)

| BIT   | NAME               | FUNCTION                                |
|-------|--------------------|-----------------------------------------|
| [7:0] | ACCEL_XOUT_H[15:8] | High byte of accelerometer x-axis data. |

Register Name: ACCEL\_XOUT\_L Register Type: READ only Register Address: 60 (Decimal); 3C (Hex)

| BIT   | NAME              | FUNCTION                               |
|-------|-------------------|----------------------------------------|
| [7:0] | ACCEL_XOUT_L[7:0] | Low byte of accelerometer x-axis data. |

Register Name: ACCEL\_YOUT\_H Register Type: READ only Register Address: 61 (Decimal); 3D (Hex)

| BIT   | NAME               | FUNCTION                                |
|-------|--------------------|-----------------------------------------|
| [7:0] | ACCEL_YOUT_H[15:8] | High byte of accelerometer y-axis data. |

Register Name: ACCEL\_YOUT\_L Register Type: READ only Register Address: 62 (Decimal); 3E (Hex)

| BIT   | NAME              | FUNCTION                               |
|-------|-------------------|----------------------------------------|
| [7:0] | ACCEL_YOUT_L[7:0] | Low byte of accelerometer y-axis data. |

Register Name: ACCEL\_ZOUT\_H Register Type: READ only Register Address: 63 (Decimal); 3F (Hex)

| BIT   | NAME               | FUNCTION                                |
|-------|--------------------|-----------------------------------------|
| [7:0] | ACCEL_ZOUT_H[15:8] | High byte of accelerometer z-axis data. |

Register Name: ACCEL\_ZOUT\_L Register Type: READ only Register Address: 64 (Decimal); 40 (Hex)

| BIT   | NAME              | FUNCTION                               |
|-------|-------------------|----------------------------------------|
| [7:0] | ACCEL_ZOUT_L[7:0] | Low byte of accelerometer z-axis data. |

#### 3.19 REGISTERS 65 AND 66 – TEMPERATURE MEASUREMENT

#### Register Name: TEMP\_OUT\_H

Register Type: READ only

Register Address: 65 (Decimal); 41 (Hex)

| BIT   | NAME           | FUNCTION                                   |
|-------|----------------|--------------------------------------------|
| [7:0] | TEMP_OUT[15:8] | High byte of the temperature sensor output |

Register Name: TEMP\_OUT\_L Register Type: READ only Register Address: 66 (Decimal); 42 (Hex)

| BIT | NAME |  |
|-----|------|--|
|     |      |  |

**FUNCTION** 



## ICM-20608-G

| BIT   | NAME          | FUNCTION          |                                      |
|-------|---------------|-------------------|--------------------------------------|
|       |               | Low byte of the t | emperature sensor output             |
|       |               | TEMP_degC         | = ((TEMP_OUT –                       |
| [7:0] | TEMP_OUT[7:0] |                   | RoomTemp_Offset)/Temp_Sensitivity) + |
|       |               |                   | 25degC                               |
|       |               |                   |                                      |

#### 3.20 REGISTERS 67 TO 72 – GYROSCOPE MEASUREMENTS

Register Name: GYRO\_XOUT\_H Register Type: READ only

Register Address: 67 (Decimal); 43 (Hex)

| BIT   | NAME            | FUNCTION                                 |
|-------|-----------------|------------------------------------------|
| [7:0] | GYRO_XOUT[15:8] | High byte of the X-Axis gyroscope output |

Register Name: GYRO\_XOUT\_L Register Type: READ only Register Address: 68 (Decimal); 44 (Hex)

| BIT   | NAME           | FUNCTION          |                                   |
|-------|----------------|-------------------|-----------------------------------|
|       | GYRO_XOUT[7:0] | Low byte of the X | -Axis gyroscope output            |
| [7:0] |                | GYRO_XOUT =       | Gyro_Sensitivity * X_angular_rate |
| [7.0] |                | Nominal           | $FS_SEL = 0$                      |
|       |                | Conditions        | Gyro_Sensitivity = 131 LSB/(º/s)  |

#### Register Name: GYRO\_YOUT\_H Register Type: READ only Register Address: 69 (Decimal); 45 (Hex)

| BIT   | NAME            | FUNCTION                                 |
|-------|-----------------|------------------------------------------|
| [7:0] | GYRO YOUT[15:8] | High byte of the Y-Axis gyroscope output |

#### Register Name: GYRO\_YOUT\_L Register Type: READ only Register Address: 70 (Decimal); 46 (Hex)

| BIT   | NAME           |             | FUNCTION                                                    |
|-------|----------------|-------------|-------------------------------------------------------------|
| [7:0] | GYRO_YOUT[7:0] | GYRO_YOUT = | -Axis gyroscope output<br>Gyro_Sensitivity * Y_angular_rate |
|       |                | Nominal     | $FS_SEL = 0$                                                |
|       |                | Conditions  | Gyro_Sensitivity = 131 LSB/(º/s)                            |

Register Name: GYRO\_ZOUT\_H Register Type: READ only Register Address: 71 (Decimal); 47 (Hex)



| BIT   | NAME            | FUNCTION                                 |
|-------|-----------------|------------------------------------------|
| [7:0] | GYRO_ZOUT[15:8] | High byte of the Z-Axis gyroscope output |

Register Name: GYRO\_ZOUT\_L Register Type: READ only Register Address: 72 (Decimal); 48 (Hex)

| BIT   | NAME           | FUNCTION                                                   |                                                                                                                      |
|-------|----------------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| [7:0] | GYRO_YOUT[7:0] | Low byte of the<br>GYRO_ZOUT<br>=<br>Nominal<br>Conditions | Z-Axis gyroscope output<br>Gyro_Sensitivity *<br>Z_angular_rate<br>FS_SEL = 0<br>Gyro_Sensitivity = 131<br>LSB/(º/s) |

#### 3.21 REGISTER 104 – SIGNAL PATH RESET

Register Name: SIGNAL\_PATH\_RESET Register Type: READ/WRITE Register Address: 104 (Decimal); 68 (Hex)

| BIT   | NAME      | FUNCTION                                                                                                             |
|-------|-----------|----------------------------------------------------------------------------------------------------------------------|
| [7:2] | -         | Reserved                                                                                                             |
| [1]   | ACCEL_RST | Reset accel digital signal path. Note: Sensor registers are not cleared. Use SIG_COND_RST to clear sensor registers. |
| [0]   | TEMP_RST  | Reset temp digital signal path. Note: Sensor registers are not cleared. Use SIG_COND_RST to clear sensor registers.  |

#### 3.22 REGISTER 105 – ACCELEROMETER INTELLIGENCE CONTROL

#### Register Name: ACCEL\_INTEL\_CTRL Register Type: READ/WRITE

#### Register Address: 105 (Decimal); 69 (Hex)

| BIT   | NAME                                                               | FUNCTION                                                |  |
|-------|--------------------------------------------------------------------|---------------------------------------------------------|--|
| [7]   | ACCEL_INTEL_EN This bit enables the Wake-on-Motion detection logic |                                                         |  |
| [6]   | ACCEL_INTEL_MODE                                                   | 0 – Do not use                                          |  |
|       |                                                                    | 1 – Compare the current sample with the previous sample |  |
| [5:0] | -                                                                  | Reserved                                                |  |

#### 3.23 REGISTER 106 – USER CONTROL

| Register Name: USER_CTRL                  |
|-------------------------------------------|
| Register Type: READ/WRITE                 |
| Register Address: 106 (Decimal); 6A (Hex) |

| BIT | NAME         | FUNCTION                                                                                                                                                         |
|-----|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7] | -            | Reserved.                                                                                                                                                        |
| [6] | FIFO_EN      | <ul> <li>1 – Enable FIFO operation mode.</li> <li>0 – Disable FIFO access from serial interface. To disable FIFO writes by DMA, use FIFO_EN register.</li> </ul> |
| [5] | -            | Reserved                                                                                                                                                         |
| [4] | I2C_IF_DIS   | 1 – Disable I2C Slave module and put the serial interface in SPI mode only.                                                                                      |
| [3] | -            | Reserved.                                                                                                                                                        |
| [2] | FIFO_RST     | 1 – Reset FIFO module. Reset is asynchronous. This bit auto clears after one clock cycle of the internal 20MHz clock.                                            |
| [1] | -            | Reserved                                                                                                                                                         |
| [0] | SIG_COND_RST | 1 – Reset all gyro digital signal path, accel digital signal path, and temp digital signal path. This bit also clears all the sensor registers.                  |

#### 3.24 REGISTER 107 – POWER MANAGEMENT 1

Register Name: PWR\_MGMT\_1 Register Type: READ/WRITE Register Address: 107 (Decimal); 6B (Hex)

| BIT   | NAME             | FUNCTION                                                                             |
|-------|------------------|--------------------------------------------------------------------------------------|
| [7]   | DEVICE_RESET     | 1 – Reset the internal registers and restores the default settings. The bit          |
| [7]   | [7] DEVICE_RESET | automatically clears to 0 once the reset is done.                                    |
| [6]   | SLEEP            | When set to 1, the chip is set to sleep mode.                                        |
| [0]   | JLLLF            | Note: The default value is 1, the chip comes up in Sleep mode                        |
|       |                  | When set to 1, and SLEEP and STANDBY are not set to 1, the chip will cycle between   |
|       |                  | sleep and taking a single accelerometer sample at a rate determined by               |
| [5]   | ACCEL_CYCLE      | SMPLRT_DIV                                                                           |
| [3]   |                  | NOTE: When all accelerometer axes are disabled via PWR_MGMT_2 register bits          |
|       |                  | and cycle is enabled, the chip will wake up at the rate determined by the respective |
|       |                  | registers above, but will not take any samples.                                      |
| [4]   | GYRO_STANDBY     | When set, the gyro drive and pll circuitry are enabled, but the sense paths are      |
| [-]   | GINO_STANDDI     | disabled. This is a low power mode that allows quick enabling of the gyros.          |
| [3]   | TEMP_DIS         | When set to 1, this bit disables the temperature sensor.                             |
|       |                  | Code Clock Source                                                                    |
|       |                  | 0 Internal 20MHz oscillator                                                          |
|       |                  | 1 Auto selects the best available clock source – PLL if ready, else use the          |
|       | CLKSEL[2:0]      | Internal oscillator                                                                  |
|       |                  | 2 Auto selects the best available clock source – PLL if ready, else use the          |
|       |                  | Internal oscillator                                                                  |
| [2:0] |                  | 3 Auto selects the best available clock source – PLL if ready, else use the          |
| [=]   |                  | Internal oscillator                                                                  |
|       |                  | 4 Auto selects the best available clock source – PLL if ready, else use the          |
|       |                  | Internal oscillator                                                                  |
|       |                  | 5 Auto selects the best available clock source – PLL if ready, else use the          |
|       |                  | Internal oscillator                                                                  |
|       |                  | 6 Internal 20MHz oscillator                                                          |
|       |                  | 7 Stops the clock and keeps timing generator in reset                                |

Note: The default value of CLKSEL[2:0] is 000. It is required that CLKSEL[2:0] be set to 001 to achieve full gyroscope performance.

#### 3.25 REGISTER 108 – POWER MANAGEMENT 2

#### Register Name: PWR\_MGMT\_2 Register Type: READ/WRITE Register Address: 108 (Decimal); 6C (Hex)

| BIT | NAME       | FUNCTION                                                               |
|-----|------------|------------------------------------------------------------------------|
| [7] | FIFO_LP_EN | 1 – Enable FIFO in low-power accelerometer mode. Default setting is 0. |
| [6] | -          | Reserved.                                                              |
| [5] | STBY_XA    | 1 – X accelerometer is disabled<br>0 – X accelerometer is on           |
| [4] | STBY_YA    | 1 – Y accelerometer is disabled<br>0 – Y accelerometer is on           |
| [3] | STBY_ZA    | 1 – Z accelerometer is disabled<br>0 – Z accelerometer is on           |
| [2] | STBY_XG    | 1 – X gyro is disabled<br>0 – X gyro is on                             |
| [1] | STBY_YG    | 1 – Y gyro is disabled<br>0 – Y gyro is on                             |
| [0] | STBY_ZG    | 1 – Z gyro is disabled<br>0 – Z gyro is on                             |

#### 3.26 REGISTER 114 AND 115 – FIFO COUNT REGISTERS

#### Register Name: FIFO\_COUNTH Register Type: READ Only Register Address: 114 (Decimal); 72 (Hex)

| -     |                  |                                                                           |
|-------|------------------|---------------------------------------------------------------------------|
| BIT   | NAME             | FUNCTION                                                                  |
| [7:5] | -                | Reserved                                                                  |
| [4:0] | FIFO COUNT[12:8] | High Bits, count indicates the number of written bytes in the FIFO.       |
| [4.0] | FIFO_COUNT[12.8] | Reading this byte latches the data for both FIFO_COUNTH, and FIFO_COUNTL. |

Register Name: FIFO\_COUNTL Register Type: READ Only Register Address: 115 (Decimal); 73 (Hex)



| BIT   | NAME            | FUNCTION                                                                                                                                               |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | FIFO_COUNT[7:0] | Low Bits, count indicates the number of written bytes in the FIFO. NOTE: Must read FIFO_COUNTH to latch new data for both FIFO_COUNTH and FIFO_COUNTL. |

#### 3.27 REGISTER 116 – FIFO READ WRITE

Register Name: FIFO\_R\_W Register Type: READ/WRITE Register Address: 116 (Decimal); 74 (Hex)

| BIT   | NAME           | FUNCTION                                                          |
|-------|----------------|-------------------------------------------------------------------|
| [7:0] | FIFO_DATA[7:0] | Read/Write command provides Read or Write operation for the FIFO. |

#### **Description:**

This register is used to read and write data from the FIFO buffer.

Data is written to the FIFO in order of register number (from lowest to highest). If all the FIFO enable flags (see below) are enabled, the contents of registers 59 through 72 will be written in order at the Sample Rate.

The contents of the sensor data registers (Registers 59 to 72) are written into the FIFO buffer when their corresponding FIFO enable flags are set to 1 in FIFO\_EN (Register 35).

If the FIFO buffer has overflowed, the status bit *FIFO\_OFLOW\_INT* is automatically set to 1. This bit is located in INT\_STATUS (Register 58). When the FIFO buffer has overflowed, the oldest data will be lost and new data will be written to the FIFO unless register 26 CONFIG, bit[6] FIFO\_MODE = 1.

If the FIFO buffer is empty, reading register FIFO\_DATA will return a unique value of 0xFF until new data is available. Normal data is precluded from ever indicating 0xFF, so 0xFF gives a trustworthy indication of FIFO empty.

#### 3.28 REGISTER 117 – WHO AM I

Register Name: WHO\_AM\_I

Register Type: READ only

| Register Address: 117 (Decimal); 75 (Hex) |        |                                                              |
|-------------------------------------------|--------|--------------------------------------------------------------|
| BIT                                       | NAME   | FUNCTION                                                     |
| [7:0]                                     | WHOAMI | Register to indicate to user which device is being accessed. |

This register is used to verify the identity of the device. The contents of *WHOAMI* is an 8-bit device ID. The default value of the register is 0xAF. This is different from the I2C address of the device as seen on the slave I2C controller by the applications processor. The I2C address of the ICM-20608-G is 0x68 or 0x69 depending upon the value driven on AD0 pin.

#### 3.29 REGISTERS 119, 120, 122, 123, 125, 126 ACCELEROMETER OFFSET REGISTERS

#### Register Name: XA\_OFFSET\_H Register Type: READ/WRITE Register Address: 119 (Decimal); 77 (Hex)

| NAME             | FUNCTION                                                                                                                         |
|------------------|----------------------------------------------------------------------------------------------------------------------------------|
| XA () = S[1]A'/[ | Upper bits of the X accelerometer offset cancellation. +/- 16g Offset cancellation in all Full Scale modes, 15 bit 0.98-mg steps |
| -                | (A OFFS[14·7]                                                                                                                    |



#### Register Name: XA\_OFFSET\_L Register Type: READ/WRITE Register Address: 120 (Decimal): 78 (Hex)

| BIT   | NAME         | FUNCTION                                                                                                                         |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------|
| [7:1] | XA_OFFS[6:0] | Lower bits of the X accelerometer offset cancellation. +/- 16g Offset cancellation in all Full Scale modes, 15 bit 0.98-mg steps |
| [0]   | -            | Reserved                                                                                                                         |

#### Register Name: YA\_OFFSET\_H Register Type: READ/WRITE Register Address: 122 (Decimal); 7A (Hex)

| BIT   | NAME          | FUNCTION                                                                           |
|-------|---------------|------------------------------------------------------------------------------------|
| [7:0] | YA OFFS[14:7] | Upper bits of the Y accelerometer offset cancellation. +/- 16g Offset cancellation |
| [7:0] | TA_0FF3[14.7] | in all Full Scale modes, 15 bit 0.98-mg steps                                      |

#### Register Name: YA\_OFFSET\_L Register Type: READ/WRITE Register Address: 123 (Decimal); 7B (Hex)

| BIT   | NAME         | FUNCTION                                                                                                                         |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------|
| [7:1] | YA_OFFS[6:0] | Lower bits of the Y accelerometer offset cancellation. +/- 16g Offset cancellation in all Full Scale modes, 15 bit 0.98-mg steps |
| [0]   | -            | Reserved                                                                                                                         |

#### Register Name: ZA\_OFFSET\_H Register Type: READ/WRITE Register Address: 125 (Decimal); 7D (Hex)

| BIT   | NAME          | FUNCTION                                                                                                                         |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | ZA_OFFS[14:7] | Upper bits of the Z accelerometer offset cancellation. +/- 16g Offset cancellation in all Full Scale modes, 15 bit 0.98-mg steps |

Register Name: ZA\_OFFSET\_L Register Type: READ/WRITE Register Address: 126 (Decimal); 7E (Hex)

| BIT   | NAME         | FUNCTION                                                                                                                         |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------|
| [7:1] | ZA_OFFS[6:0] | Lower bits of the Z accelerometer offset cancellation. +/- 16g Offset cancellation in all Full Scale modes, 15 bit 0.98-mg steps |
| [0]   | -            | Reserved                                                                                                                         |



### 4 REVISION HISTORY

| Revision Date | Revision | Description     |
|---------------|----------|-----------------|
| 06/15/2015    | 1.0      | Initial Release |

This information furnished by InvenSense is believed to be accurate and reliable. However, no responsibility is assumed by InvenSense for its use, or for any infringements of patents or other rights of third parties that may result from its use. Specifications are subject to change without notice. InvenSense reserves the right to make changes to this product, including its circuits and software, in order to improve its design and/or performance, without prior notice. InvenSense makes no warranties, neither expressed nor implied, regarding the information and specifications contained in this document. InvenSense assumes no responsibility for any claims or damages arising from information contained in this document, or from the use of products and services detailed therein. This includes, but is not limited to, claims or damages based on the infringement of patents, copyrights, mask work and/or other intellectual property rights.

Certain intellectual property owned by InvenSense and described in this document is patent protected. No license is granted by implication or otherwise under any patent or patent rights of InvenSense. This publication supersedes and replaces all information previously supplied. Trademarks that are registered trademarks are the property of their respective companies. InvenSense sensors should not be used or sold in the development, storage, production or utilization of any conventional or mass-destructive weapons or for any other weapons or life threatening applications, as well as in any other life critical applications such as medical equipment, transportation, aerospace and nuclear instruments, undersea equipment, power plant equipment, disaster prevention and crime prevention equipment.

©2015 InvenSense, Inc. All rights reserved. InvenSense, MotionTracking, MotionProcessing, MotionProcessor, MotionFusion, MotionApps, DMP, and the InvenSense logo are trademarks of InvenSense, Inc. Other company and product names may be trademarks of the respective companies with which they are associated.



©2015 InvenSense, Inc. All rights reserved.