### **General Description**

The MAX86140 is an ultra-low-power, completely integrated, optical data acquisition system. On the transmitter side, the MAX86140 has three programmable high-current LED drivers that can be configured to drive up to six LEDs. With two MAX86140 devices working in master-slave mode, the LED drivers can drive up to twelve LEDs. On the receiver side, MAX86140 has a low-noise signal conditioning analog front-end (AFE) including a 19-bit ADC, an industry-lead ambient light cancellation (ALC) circuit, and a picket fence detect and replace algorithm. Due to the low power consumption, compact size, easy/flexible-to-use and industry-lead ambient light rejection capability of MAX86140, the device is ideal for a wide variety of optical sensing applications, such as pulse oximetry and heart rate detection.

The MAX86140 operates on a 1.8V main supply voltage and a 3.1~5.5V LED driver supply voltage. The device supports a standard SPI compatible interface and fully autonomous operation. The device has a large 128-word built-in FIFO. The MAX86140 is available in compact WLP package (2.048x1.848mm) with 0.4mm ball pitch.

### **Applications**

- Wearable Devices for Fitness, Wellness and Medical Applications
- Optimized for Wrist, Finger, Ear, and Other Locations
- Optimized Performance to Detect
  - · Optical Heart Rate
  - Oxygen Saturation (SpO<sub>2</sub>)
  - Muscle Oxygen Saturation (SmO<sub>2</sub> and StO<sub>2</sub>)

#### **Benefits and Features**

- Complete Single-Channel, Optical Data Acquisition System
- Built-in Algorithm Further Enhances Rejection of Fast Ambient Transients
- Optimized Architecture for Transmissive and Reflective Heart Rate or SpO<sub>2</sub> Monitoring
- Low Dark Current Noise of < 50pA RMS (Sample to Sample Variance)
- Lower Effective Dark Current Noise Achievable Through Multiple Sample Modes and On-Chip Averaging
- High-Resolution, 19-bit Charge Integrating ADC
- Three Low-Noise, 8-Bit LED Current DACs
- Excellent Dynamic Range >90dB in White Card Loop-Back Test (Sample-to-Sample Variance)
- Dynamic Range Extendable to >104dB for SpO<sub>2</sub> and >110dB for HRM with Multiple Sample Modes and On-Chip Averaging
- Excellent Ambient Range and Rejection Capability
  - > 100µA Ambient Photodetector Current
  - > 70dB Ambient Rejection at 120Hz
- Ultra-Low-Power Operation for Body Wearable Devices
  - Low-Power Operation, Optical Readout Channel <10µA Typical at 25sps</li>
  - Short Exposure Integration Period of 14.8µs, 29.4µs, 58.7µs, 117.3µs
  - Low Shutdown Current = 20µW Typical
- Built-in Algorithm Further Enhances Rejection of Fast Ambient Transients
- Miniature 2.048 x 1.848mm, 5 x 4 0.4mm Ball Pitch WLP
- -40°C to +85°C Operating Temperature Range

Ordering Information appears at end of data sheet.



### **Simplified Block Diagram**



### **Absolute Maximum Ratings**

| VDD_ANA to GND_ANA0.3V to +2.2V                  | PD1_IN to GND_ANA0.3V to +2.2V           |
|--------------------------------------------------|------------------------------------------|
| VDD_DIG to GND_ANA0.3V to +2.2V                  | PD_GND to GND_ANA0.3V to +0.3V           |
| VDD_ANA to VDD_ANA0.3V to +0.3V                  | All other pins to GND_ANA0.3V to +2.2V   |
| PGND to GND_ANA0.3V to +0.3V                     | Output Short-Circuit Duration            |
| SCLK, SDO, SDI, CSB, INT to GND_ANA0.3V to +6.0V | Continuous Input Current Into Any Pin    |
| GND_DIG to GND_ANA0.3V to +0.3V                  | (except LED_DRVx Pins)±20mA              |
| VLED to PGND0.3V to +6.0V                        | Continuous Power Dissipation (WLP        |
| LED_DRV1 to PGND0.3V to V <sub>LED</sub> + 0.3V  | (derate 5.5mW/°C above +70°C))           |
| LED_DRV2 to PGND0.3V to V <sub>LED</sub> + 0.3V  | Operating Temperature Range40°C to +85°C |
| LED_DRV3 to PGND0.3V to V <sub>LED</sub> + 0.3V  | Storage Temperature Range40°C to +105°C  |

Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of the specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

### **Package Information**

### 5 x 4 WLP

| PACKAGE CODE                           | N201A2+1                       |
|----------------------------------------|--------------------------------|
| Outline Number                         | 21-100134                      |
| Land Pattern Number                    | Refer to Application Note 1891 |
| Thermal Resistance, Four-Layer Board:  |                                |
| Junction to Ambient (θ <sub>JA</sub> ) | 55.49°C/W                      |
| Junction to Case (θ <sub>JC</sub> )    | N/A                            |

For the latest package outline information and land patterns (footprints), go to <a href="www.maximintegrated.com/packages">www.maximintegrated.com/packages</a>. Note that a "+", "#", or "-" in the package code indicates RoHS status only. Package drawings may show a different suffix character, but the drawing pertains to the package regardless of RoHS status.

Package thermal resistances were obtained using the method described in JEDEC specification JESD51-7, using a four-layer board. For detailed information on package thermal considerations, refer to www.maximintegrated.com/thermal-tutorial.

### **Electrical Characteristics**

(VDDANA = 1.8V, VDDDIG = 1.8V, VLED = 5.0V, ADC\_RGE =  $16\mu A$ , PPG\_SR = 1024sps, PPG\_TINT =  $14.8\mu s$ , LED\_SETLNG =  $6\mu s$ , LEDx\_RGE = 31mA, CPD = 65pF, PD\_BIAS = 0x1, I $_{exposure}$  =  $1\mu A$ , T $_A$  =  $25^{\circ}C$ , min/max are from T $_A$  =  $-40^{\circ}C$  to  $+85^{\circ}C$ , unless otherwise noted. (Note 1) )

| PARAMETER                    | SYMBOL           | CONDITI                                                                          | ONS               | MIN  | TYP   | MAX | UNITS  |  |  |  |
|------------------------------|------------------|----------------------------------------------------------------------------------|-------------------|------|-------|-----|--------|--|--|--|
| Readout Channel              |                  |                                                                                  |                   |      | •     |     |        |  |  |  |
| ADC Resolution               |                  |                                                                                  |                   |      | 19    |     | bits   |  |  |  |
|                              |                  | ADC_RGE = 0x0                                                                    |                   |      | 4.0   |     |        |  |  |  |
|                              |                  | ADC_RGE = 0x1                                                                    |                   |      | 8.0   |     |        |  |  |  |
| ADC Full Scale Input Current |                  | ADC_RGE = 0x2                                                                    |                   |      | 16.0  |     | μA     |  |  |  |
|                              |                  | ADC_RGE = 0x3                                                                    |                   |      | 32.0  |     |        |  |  |  |
|                              |                  | PPG_TINT = 0x0                                                                   |                   |      | 14.8  |     |        |  |  |  |
|                              |                  | PPG_TINT = 0x1                                                                   |                   |      | 29.4  |     |        |  |  |  |
| ADC Integration Time         | t <sub>INT</sub> | PPG_TINT = 0x2                                                                   |                   |      | 58.7  |     | μs     |  |  |  |
|                              |                  | PPG_TINT = 0x3                                                                   |                   |      | 117.3 |     |        |  |  |  |
| Minimum PPG Sample Rate      |                  | PPG_SR = 0x0A                                                                    |                   |      | 8     |     | sps    |  |  |  |
| Maximum PPG Sample Rate      |                  | PPG_SR = 0x13                                                                    |                   |      | 4096  |     | sps    |  |  |  |
| Sample Rate Error            |                  | From nominal as indicate table                                                   | ed in the PPG_SR  | -2   |       | +2  | %      |  |  |  |
| DC Ambient Light Input Range | ALR              | ALC = on, ALC_OVF = 1                                                            | [                 | 200  |       |     | μA     |  |  |  |
| AC Ambient Light Rejection   | AC_ALRR          | ALC = on, I <sub>ambient</sub> = 1µ/<br>±0.4µA pk-pk 120Hz Sin                   |                   |      | 70    |     | dB     |  |  |  |
| DC Ambient Light Rejection   |                  | ALC = on, I <sub>ambient</sub> modu<br>and 30µA, LED_SETLN<br>PPG_TINT = 117.3µs |                   |      | 0.5   |     | nA     |  |  |  |
| Dark Current Offset          | DC_O             | ALC = ON, PD_BIAS = 0x                                                           | 0, ADD_OFFSET = 1 |      | ±9    |     | Counts |  |  |  |
|                              |                  | PPG_TINT = 14.8µs                                                                |                   |      | 262   |     |        |  |  |  |
| Dark Current Input Referred  |                  | PPG_TINT = 29.4µs                                                                |                   |      | 128   |     | pArms  |  |  |  |
| Noise                        |                  | PPG_TINT = 58.7µs                                                                |                   |      | 83    |     |        |  |  |  |
|                              |                  | PPG_TINT = 117.3µs                                                               |                   |      | 56    |     | pArms  |  |  |  |
|                              |                  |                                                                                  | PD_BIAS = 0x1     |      | 65    |     |        |  |  |  |
| Maximum Photodiode Input     |                  | I <sub>ambient</sub> = 0μA, less                                                 | PD_BIAS = 0x5     |      | 130   |     |        |  |  |  |
| Capacitance                  | C <sub>pd</sub>  | than 1nA of code shift                                                           | PD_BIAS = 0x6     |      | 260   |     | pF     |  |  |  |
|                              |                  |                                                                                  | PD_BIAS = 0x7     |      | 520   |     |        |  |  |  |
| VDD DC PSR                   |                  | I <sub>ambient</sub> = 0μA, V <sub>DD</sub> = 1.                                 | 7V to 2.0V        | -500 | -330  | 500 | LSB/V  |  |  |  |
| LED Driver                   |                  |                                                                                  |                   |      |       |     |        |  |  |  |
| LED Current Resolution       |                  |                                                                                  |                   |      | 8     |     | Bits   |  |  |  |
| Driver DNL                   |                  | LEDx_RGE = 124mA                                                                 |                   | -1   |       | 1   | LSB    |  |  |  |
| Driver INL                   |                  | LEDx_RGE = 124mA                                                                 |                   |      | 0.5   |     | LSB    |  |  |  |

### **Electrical Characteristics (continued)**

(VDDANA = 1.8V, VDDDIG = 1.8V, VLED = 5.0V, ADC\_RGE =  $16\mu$ A, PPG\_SR = 1024sps, PPG\_TINT =  $14.8\mu$ s, LED\_SETLNG =  $6\mu$ s, LEDx\_RGE = 31mA, C<sub>PD</sub> = 65pF, PD\_BIAS = 0x1, I $_{exposure}$  =  $1\mu$ A, T<sub>A</sub> = 25°C, min/max are from T<sub>A</sub> = -40°C to +85°C, unless otherwise noted. (Note 1) )

| PARAMETER                           | SYMBOL               | CONDITIO                                                    | ONS                             | MIN | TYP | MAX  | UNITS    |
|-------------------------------------|----------------------|-------------------------------------------------------------|---------------------------------|-----|-----|------|----------|
|                                     |                      |                                                             | LEDx_RGE = 0x0                  |     | 31  |      |          |
| 5 # 0 la 1 5D 0 (Nata 0)            |                      | LED DA OLEE                                                 | LEDx_RGE = 0x1                  |     | 62  |      |          |
| Full Scale LED Current (Note 3)     | I <sub>LED</sub>     | LEDx_PA = 0xFF                                              | LEDx_RGE = 0x2                  |     | 93  |      | mA       |
|                                     |                      |                                                             | LEDx_RGE = 0x3                  | 117 | 124 | 129  |          |
|                                     |                      |                                                             | LEDx_RGE = 0x0                  |     | 160 | 253  |          |
| Minimum output voltage              | \/                   | LEDx_PA = 0xFF,<br>95% of the desired LED                   | LEDx_RGE = 0x1                  |     | 317 |      | mV       |
| Minimum output voltage              | V <sub>OL</sub>      | current                                                     | LEDx_RGE = 0x2                  |     | 495 |      | IIIV     |
|                                     |                      |                                                             | LEDx_RGE = 0x3                  |     | 700 |      |          |
| LED Driver DC PSR                   |                      | $V_{DD}$ = 1.8V, VLEDx_DRV<br>$V_{LED}$ = 3.1 to 5.5V, LED: | x_RGE = 124mA                   |     | -1  | 800  | μΑ/V     |
|                                     |                      | $V_{DD}$ = 1.7 to 2.0V, $T_A$ = -                           | +25°C                           |     | 110 | 1410 |          |
| LED1 Driver Compliance<br>Interrupt | LED1 <sub>COMP</sub> |                                                             |                                 |     | 180 |      | mV       |
| Internal Die Temperature Sense      | or                   |                                                             |                                 |     |     |      |          |
| Temperature Sensor Accuracy         |                      | T <sub>A</sub> = 25°C                                       |                                 |     | 1   |      | °C       |
| Temperature Sensor Minimum Range    |                      | Temperature error < 5°C                                     |                                 |     | -40 |      | °C       |
| Temperature Sensor Maximum Range    |                      | Temperature error < 5°C                                     |                                 | 85  |     | °C   |          |
| Temperature ADC Acquisition Time    |                      |                                                             |                                 |     | 29  |      | ms       |
| Power Supply                        |                      |                                                             |                                 |     |     |      |          |
| Power Supply Voltage                | V <sub>DD</sub>      | Verified during PSRR Tes                                    | st                              | 1.7 | 1.8 | 2.0  | <b>V</b> |
| LED Supply Voltage                  | V <sub>LED</sub>     | Verified during PSRR Tes                                    | st                              | 3.1 |     | 5.5  | V        |
|                                     |                      | Single LED Exposure/Sa<br>4096sps, LP_MODE = 0              |                                 |     | 660 | 780  |          |
|                                     |                      | Single LED Exposure/                                        | PPG_SR = 256sps                 |     | 80  |      |          |
|                                     |                      | Sample, PW = 14.8µs,<br>LP_MODE = 0x1,                      | PPG_SR = 100sps                 |     | 32  |      | μA       |
| VDD Supply Current                  | I <sub>DD</sub>      | LEDx_PA = 0mA                                               | PPG_SR = 50sps                  |     | 16  |      |          |
| 122 Supply Sulfolit                 | טטי                  |                                                             | PPG_SR = 25sps                  |     | 8.5 |      |          |
|                                     |                      | Two LED Exposure/<br>Sample, PW = 14.8µs,                   | PPG_SR = 84sps,<br>single-pulse |     | 42  |      | μA       |
|                                     |                      | LP_MODE = 0x1,<br>LEDx_PA = 0mA                             | PPG_SR = 84sps                  |     | 89  |      | μA       |
|                                     |                      | Die Temperature mode, S<br>Channel(s) disabled              | SPS = 1, Optical                |     | 8   |      | μA       |

### **Electrical Characteristics (continued)**

(VDDANA = 1.8V, VDDDIG = 1.8V, VLED = 5.0V, ADC\_RGE = 16 $\mu$ A, PPG\_SR = 1024sps, PPG\_TINT = 14.8 $\mu$ s, LED\_SETLNG = 6 $\mu$ s, LEDx\_RGE = 31mA, CPD = 65pF, PD\_BIAS = 0x1, I<sub>exposure</sub> = 1 $\mu$ A, T<sub>A</sub> = 25°C, min/max are from T<sub>A</sub> = -40°C to +85°C, unless otherwise noted. (Note 1) )

| PARAMETER                           | SYMBOL              | CONDITIO                                                                    | ONS             | MIN                      | TYP  | MAX | UNITS |
|-------------------------------------|---------------------|-----------------------------------------------------------------------------|-----------------|--------------------------|------|-----|-------|
|                                     |                     | Single LED exposure per<br>TINT = 117.3µs, Single-F<br>PPG_SR = 256sps, LED | Pulse,          |                          | 0.22 |     |       |
|                                     |                     | Single LED exposure                                                         | PPG_SR = 256sps |                          | 1865 |     |       |
|                                     |                     | per Sample, PPG_TINT = 117.3µs, Single-Pulse,                               | PPG_SR = 100sps |                          | 730  |     | μA    |
| VI ED Comple Compant                |                     | LEDx_PA = 62mA                                                              | PPG_SR = 50sps  |                          | 365  |     |       |
| VLED Supply Current                 | I <sub>LED</sub>    | Single LED exposure per<br>Sample, PPG_TINT =<br>117.3µs, single-pulse      | PPG_SR=25sps    |                          | 182  |     |       |
|                                     |                     | Two LED exposure per                                                        | Single-Pulse    |                          | 1225 |     |       |
|                                     |                     | sample, PPG_TINT =<br>117.3µs, LEDx_PA =<br>62mA, PPG_SR = 84sps            | Dual-Pulse      |                          | 2455 |     | μA    |
| VDD Current in Shutdown             |                     | T <sub>A</sub> = +25°C                                                      |                 |                          | 0.6  | 2.5 | uA    |
| VLED Current in Shutdown            |                     | T <sub>A</sub> = +25°C                                                      |                 |                          |      | 1   | uA    |
| Digital I/O Characteristics         |                     |                                                                             |                 |                          |      |     |       |
| SDO Output Low Voltage              | V <sub>OL_SDO</sub> | SDO I <sub>SINK</sub> = 2mA                                                 |                 |                          |      | 0.4 | V     |
| SDO Output High Voltage             | V <sub>OH_SDO</sub> | I <sub>SOURCE</sub> = 2mA                                                   |                 | V <sub>DD</sub> -<br>0.4 |      |     | V     |
| Open-Drain Output Low Voltage       | V <sub>OL_OD</sub>  | I <sub>SINK</sub> = 6mA, INTB, GPI                                          | D1, GPIO2       |                          |      | 0.4 | V     |
| Input Voltage Low                   | $V_{IL}$            | SDI, SCLK, CSB, GPIO1                                                       | , GPIO2         |                          |      | 0.4 | V     |
| Input Voltage High                  | $V_{IH}$            | SDI, SCLK, CSB, GPIO1                                                       | , GPIO2         | 1.4                      |      |     | V     |
| Input Hysteresis                    | V                   | SDI, SCLK, CSB                                                              |                 |                          | 320  |     | mV    |
| input Hysteresis                    | V <sub>HYS</sub>    | GPIO1, GPO2                                                                 |                 |                          | 220  |     | IIIV  |
| Input Leakage Current               | I <sub>IN</sub>     | V <sub>IN</sub> = 0V, T <sub>A</sub> = +25°C (SI<br>GPIO1, GPIO2)           | DI, SCLK, CSB,  |                          | 0.01 | 1   | μA    |
| Input Capacitance                   | C <sub>IN</sub>     | SDI, SCLK, CSB, GPIO1                                                       | , GPIO2         |                          | 10   |     | pF    |
| SPI Timing Charateristics           |                     |                                                                             |                 |                          |      |     |       |
| SCLK Frequency                      | f <sub>SCLK</sub>   |                                                                             |                 |                          |      | 8   | MHz   |
| SCLK Period                         | t <sub>CP</sub>     |                                                                             |                 | 125                      |      |     | ns    |
| SCLK Pulse Width High               | t <sub>CH</sub>     |                                                                             |                 | 40                       |      |     | ns    |
| SCLK Pulse Width Low                | t <sub>CL</sub>     |                                                                             |                 | 40                       |      |     | ns    |
| CSB Fall to SCLK Rise Setup<br>Time | t <sub>CSS0</sub>   | To 1st SCLK rising edge                                                     |                 | 20                       |      |     | ns    |

### **Electrical Characteristics (continued)**

(VDD<sub>ANA</sub> = 1.8V, VDD<sub>DIG</sub> = 1.8V, V<sub>LED</sub> = 5.0V, ADC\_RGE = 16 $\mu$ A, PPG\_SR = 1024sps, PPG\_TINT = 14.8 $\mu$ s, LED\_SETLNG = 6 $\mu$ s, LEDx\_RGE = 31mA, C<sub>PD</sub> = 65pF, PD\_BIAS = 0x1, I<sub>exposure</sub> = 1 $\mu$ A, T<sub>A</sub> = 25°C, min/max are from T<sub>A</sub> = -40°C to +85°C, unless otherwise noted. (Note 1) )

| PARAMETER                           | SYMBOL               | CONDITIONS                                                | MIN   | TYP | MAX   | UNITS |
|-------------------------------------|----------------------|-----------------------------------------------------------|-------|-----|-------|-------|
| CSB Fall to SCLK Rise Hold<br>Time  | t <sub>CSH0</sub>    | Applies to inactive rising edge preceding 1st rising edge | 5     |     |       | ns    |
| CSB Rise to SCLK Rise Hold<br>Time  | t <sub>CSH1</sub>    | Applies to 24th rising edge                               | 500   |     |       | ns    |
| SCLK Rise to CSB Fall               | t <sub>CSF</sub>     | Applies to 24th rising edge                               | 500   |     |       | ns    |
| CSB Pulse Width High                | tcspw                |                                                           | 250   |     |       | ns    |
| SDI to SCLK Rise Setup Time         | t <sub>DS</sub>      |                                                           | 10    |     |       | ns    |
| SDI to SCLK Rise Hold Time          | t <sub>DH</sub>      |                                                           | 10    |     |       | ns    |
| SCLK Fall to SDO Transition         | t <sub>DOT</sub>     | C <sub>LOAD</sub> = 50pF                                  |       |     | 35    | ns    |
| CSB Fall to SDO Enabled             | t <sub>DOE</sub>     | C <sub>LOAD</sub> = 0pF                                   | 12    |     |       | ns    |
| CSB Rise to SDO Hi-Z                | t <sub>DOZ</sub>     | Disable Time                                              |       |     | 25    | ns    |
| GPIO1 External Sync Pulse<br>Width  | t <sub>PLGPIO1</sub> |                                                           | 64    |     |       | μs    |
| GPIO2 External Clock Input (Note 4) | f <sub>GPIO2</sub>   | External Sample Reference Clock on GPIO2                  | 31900 |     | 32868 | Hz    |
| GPIO2 External Clock Pulse<br>Width | t <sub>PWGPIO2</sub> |                                                           | 1     |     |       | μs    |

- **Note 1:** All devices are 100% production tested at T<sub>A</sub> = +25°C. Specifications over temperature limits are guaranteed by MaximIntegrated's bench or proprietary automated test equipment (ATE) characterization.
- **Note 2:** Specifications are guaranteed by Maxim Integrated's bench characterization and by 100% production test using proprietary-ATE setup and conditions.
- Note 3: The LED current is trim in production to meet the IR and RED ADC counts. Actual values may vary by up to +/-50%. Values shown here are for 0%trim.
- Note 4: See Register Map/PPG Configuration 2 (0x12) section for the sample rate by the external clock frequency. The sample rate will be shifted when the external clock frequency shifts.

### **Typical Operating Characteristics**

 $(V_{DD} = 1.8V, V_{LED} = 5.0V, GND = PGND = 0V, T_A = +25^{\circ}C, unless otherwise noted.)(T_A = +25^{\circ}C, unless otherwise noted.)$ 













### **Typical Operating Characteristics (continued)**

 $(V_{DD} = 1.8V, V_{LED} = 5.0V, GND = PGND = 0V, T_A = +25^{\circ}C, unless otherwise noted.)$ 









## **Pin Configurations**



## **Pin Description**

| PIN            | NAME     | FUNCTION                                                                                                                                           |
|----------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Power          |          |                                                                                                                                                    |
| C2             | VDD_DIG  | Digital Logic Supply. Connect to externally-regulated supply. Bypass to GND_DIG                                                                    |
| C3             | GND_DIG  | Digital Logic and Digital Pad Return. Connect to GND.                                                                                              |
| D2             | VDD_ANA  | Analog Supply. Connect to externally-regulated supply. Bypass with a 0.1µF capacitor as close as possible to bump and a 10µF capacitor to GND_ANA. |
| C4             | GND_ANA  | Analog Power Return. Connect to GND.                                                                                                               |
| A1             | VLED     | LED Power Supply Input. Connect to external voltage supply. Bypass with a 10µF capacitor to PGND.                                                  |
| D3             | PGND     | LED Power Return. Connect to GND.                                                                                                                  |
| Control Interf | ace      |                                                                                                                                                    |
| A2             | SCLK     | SPI Clock                                                                                                                                          |
| A3             | SDO      | SPI Data Ouput                                                                                                                                     |
| A4             | SDI      | SPI Data Input                                                                                                                                     |
| A5             | CSB      | SPI Chip select                                                                                                                                    |
| B2             | ĪNT      | Interrupt. Programmable Open-Drain Interrupt output signal pin (Active Low).                                                                       |
| В3             | GPIO1    | General Purpose I/O                                                                                                                                |
| B4             | GPIO2    | General Purpose I/O                                                                                                                                |
| Optical Pins   |          |                                                                                                                                                    |
| D5             | PD1_IN   | Photodiode Cathode Input                                                                                                                           |
| C5             | PD_GND   | Photodiode Anode                                                                                                                                   |
| D1             | LED1_DRV | LED Output Driver 1. Connect the LED cathode to LED1_DRV and its anode to the V <sub>LED</sub> supply.                                             |
| C1             | LED2_DRV | LED Output Driver 2. Connect the LED cathode to LED2_DRV and its anode to the V <sub>LED</sub> supply.                                             |
| B1             | LED3_DRV | LED Output Driver 3 Connect the LED cathode to LED3_DRV and its anode to the V <sub>LED</sub> supply.                                              |
| Reference      |          |                                                                                                                                                    |
| B5             | VREF     | Internal Reference Decoupling Point. Bypass with a 1µF capacitor to GND_ANA                                                                        |
| N.C.           |          |                                                                                                                                                    |
| D4             | N.C.     | No Connection. Connect to unconnected PCB pad for mechanical stability. N.C. pins should not be connected to any signal, power, or ground pins.    |

### **Detailed Description**

The MAX86140 are complete integrated optical data acquisition systems, ideal for optical pulse oximetry and heart rate detection applications. The part has been designed for the demanding requirements of mobile and wearable devices and require minimal external hardware components are necessary for integration into a wearable device. It includes a high-resolution optical readout signal processing channels with robust ambient light cancellation and high current LED driver DACs to form a complete optical readout signal chain.

The MAX86140 are fully adjustable through software registers and the digital output data is stored in a 128 word FIFO within the IC. The FIFO allows the MAX86140 to be connected to a microcontroller or processor on a shared bus, where the data is not being read continuously from the MAX86140's registers. MAX86140 operates in fully autonomous modes for low power battery applications.

The MAX86140 consists of a single optical readout channel and three LED drivers and are well suited for a wide variety of optical sensing applications.

The MAX86140 operate on a 1.8V main supply voltage, with a separate 3.1V to 5.5V LED driver power supply. The device has flexible timing and shutdown configurations, as well as control of individual blocks so an optimized measurement can be made at minimum power levels.

#### **Optical Subsystem**

The optical subsystem in MAX86140 is composed of ambient light cancellation (ALC), a continuous-time sigma-delta ADC, and proprietary discrete time filter. ALC incorporates a proprietary scheme to cancel ambient light generated photo diode current, allowing the sensor to work in high ambient light conditions. The optical ADC

has programmable full-scale ranges of  $4\mu A$  to  $32\mu A$ . The internal ADC is a continuous time oversampling sigma delta converter with 19-bit resolution. The ADC output data rate can be programmed from 8sps (samples per second) to 8192sps. The MAX86140 includes a proprietary discrete time filter to reject 50Hz/60Hz interference and changing residual ambient light from the sensor measurements.

The MAX86140 supports Dynamic Power Down mode (Low Power Mode) in which the power consumption is decreased between samples. This mode is only supported for sample rates 128sps and below. For more details on the power consumption at each sample rates, refer to the *Electrical Characteristics* table.

#### **LED Driver**

The MAX86140 integrates three precision LED driver current DACs that modulate LED pulses for a variety of optical measurements. The LED current DACs have 8-bits of dynamic range with four programmable full-scale ranges of 31mA, 62mA, 94mA, and 124mA. The LED drivers are low dropout current sources allowing for low-noise, power-supply independent LED currents to be sourced at the lowest supply voltage possible, thus minimizing LED power consumption. The LED pulse width can be programmed from 14.8µs to 117.3µs µs to allow the algorithms to optimize SpO<sub>2</sub> and HR accuracy at the lowest dynamic power consumption dictated by the application.

### **FIFO Configuration**

The FIFO is 128 sample depth and is designed to support various Data Type as shown in  $\underline{\text{Table 2}}$ . Each exposure sample width is 3 byte, which includes a 5-bit Tag width. The tag embedded in the FIFO\_DATA is used to identify the source of each sample data. The description of each tag is as shown in  $\underline{\text{Table 3}}$ .

### LED Sequence Control (address 0x20 ~ 0x22)

The data format in the FIFO as well as the sequencing of exposures are controlled by the LED Sequence Registers via LEDC1 through LEDC6. There are six LED Sequence Data Items available as shown in <u>Table 1</u>. The exposure sequence cycles through the LED Sequence bit fields, starting from LEDC1 to LEDC6. The first LED Sequence field set to NONE (0000) ends the sequence.

**Table 1. LED Sequence Control Registers** 

| ADDRESS | REGISTER<br>NAME              | DEFAULT<br>VALUE | В7 | В6   | B5      | B4 | В3         | B2   | B1      | В0 |  |  |  |
|---------|-------------------------------|------------------|----|------|---------|----|------------|------|---------|----|--|--|--|
| 0x20    | LED<br>Sequence<br>Register 1 | 00               |    | LEDC | 2[3:0]  |    | LEDC1[3:0] |      |         |    |  |  |  |
| 0x21    | LED<br>Sequence<br>Register 2 | 00               |    | LEDC | 24[3:0] |    | LEDC3[3:0] |      |         |    |  |  |  |
| 0x22    | LED<br>Sequence<br>Register 3 | 00               |    | LEDC | 06[3:0] |    |            | LEDC | C5[3:0] |    |  |  |  |

Table 2 lists the codes for exposures selected in the LED sequence control registers.

**Table 2. LED Sequence Register Data Type** 

| LEDCN[3:0] | DATA TYPE                                  |  |  |  |  |  |  |  |
|------------|--------------------------------------------|--|--|--|--|--|--|--|
| 0000       | NONE                                       |  |  |  |  |  |  |  |
| 0001       | LED1                                       |  |  |  |  |  |  |  |
| 0010       | LED2                                       |  |  |  |  |  |  |  |
| 0011       | LED3                                       |  |  |  |  |  |  |  |
| 0100       | LED1 and LED2 pulsed simultaneously        |  |  |  |  |  |  |  |
| 0101       | LED1 and LED3 pulsed simultaneously        |  |  |  |  |  |  |  |
| 0110       | LED2 and LED3 pulsed simultaneously        |  |  |  |  |  |  |  |
| 0111       | LED1, LED2, and LED3 pulsed simultaneously |  |  |  |  |  |  |  |
| 1000       | Pilot on LED1                              |  |  |  |  |  |  |  |
| 1001       | DIRECT AMBIENT                             |  |  |  |  |  |  |  |
| 1010       | LED4 (external mux control)                |  |  |  |  |  |  |  |
| 1011       | LED5 (external mux control)                |  |  |  |  |  |  |  |
| 1100       | LED6 (external mux control)                |  |  |  |  |  |  |  |
| 1101       | Reserved                                   |  |  |  |  |  |  |  |
| 1110       | Reserved                                   |  |  |  |  |  |  |  |
| 1111       | Reserved                                   |  |  |  |  |  |  |  |

<u>Table 3</u> shows the format of the FIFO data along with the associated Tag. In a sample if a picket fence event is detected, the predicted value is pushed to the FIFO along with its tag (PPGx\_LECCx\_DATA).

**Table 3. FIFO Data and Tag** 

| TAG[4:0] | DATA TYPE       | FIFO_DATA[23:0]  | COMMENTS                                                           |
|----------|-----------------|------------------|--------------------------------------------------------------------|
| 00001    | PPG1_LEDC1_DATA | LEDC1_DATA[18:0] | If LEDC1 is non-zero                                               |
| 00010    | PPG1_LEDC2_DATA | LEDC2_DATA[18:0] | If LEDC1 and LEDC2 are non-zero                                    |
| 00011    | PPG1_LEDC3_DATA | LEDC3_DATA[18:0] | If LEDC1, LEDC2 and LEDC3 are non-zero                             |
| 00100    | PPG1_LEDC4_DATA | LEDC4_DATA[18:0] | If LEDC1, LEDC2, LEDC3, and LEDC4 are non-zero                     |
| 00101    | PPG1_LEDC5_DATA | LEDC5_DATA[18:0] | If LEDC1, LEDC2, LEDC3, LEDC4, and LEDC5 are non-zero              |
| 00110    | PPG1_LEDC6_DATA | LEDC6_DATA[18:0] | If LEDC1, LEDC2, LEDC3, LEDC4, LEDC5, and LEDC6 are non-zero       |
| 00111    | Reserved        | _                |                                                                    |
| 01000    | Reserved        | _                |                                                                    |
| 01001    | Reserved        | _                |                                                                    |
| 01010    | Reserved        | _                |                                                                    |
| 01011    | Reserved        | _                |                                                                    |
| 01100    | Reserved        | _                |                                                                    |
| 01101    | PPF1_LEDC1_DATA | LEDC1_DATA[18:0] | If LEDC1 is non-zero (Picket Fence Event)                          |
| 01110    | PPF1_LEDC2_DATA | LEDC2_DATA[18:0] | If LEDC1 and LEDC2 are non-zero (Picket Fence Event)               |
| 01111    | PPF1_LEDC3_DATA | LEDC3_DATA[18:0] | If LEDC1, LEDC2 and LEDC3 are non-<br>zero (Picket Fence Event)    |
| 10000    | Reserved        | _                |                                                                    |
| 10001    | Reserved        | _                |                                                                    |
| 10010    | Reserved        | _                |                                                                    |
| 10011    | Reserved        | _                |                                                                    |
| 10100    | Reserved        | _                |                                                                    |
| 10101    | Reserved        | _                |                                                                    |
| 10110    | Reserved        | _                |                                                                    |
| 10111    | Reserved        | _                |                                                                    |
| 11000    | Reserved        | _                |                                                                    |
| 11001    | PROX1_DATA      | PROX1_DATA[18:0] | Only PILOT LED1 for LEDC1 is used                                  |
| 11010    | Reserved        | _                |                                                                    |
| 11011    | Reserved        | _                |                                                                    |
| 11100    | Reserved        | _                |                                                                    |
| 11101    | Reserved        | _                |                                                                    |
| 11110    | INVALID_DATA    | Don't_care[18:0] | This tag indicates that there was an attempt to read an empty FIFO |
| 11111    | TIME_STAMP      | TIME_STAMP[18:0] | If TIME_STAMP_EN = 1, this is TIME_<br>STAMP                       |

There are seven registers that control how the FIFO is configured and read out. These registers are illustrated below.

**Table 4. PPG Configuration** 

| ADDRESS | REGISTER<br>NAME          | В7 | В6                   | B5                    | B4             | В3                | B2              | B1      | В0 |  |  |  |  |  |
|---------|---------------------------|----|----------------------|-----------------------|----------------|-------------------|-----------------|---------|----|--|--|--|--|--|
| 0X04    | FIFO Write<br>Pointer     |    |                      | _                     |                | FIFO_WR_PTR[6:0]  |                 |         |    |  |  |  |  |  |
| 0X05    | FIFO Read<br>Pointer      |    |                      | _                     |                | FIFO_RD_PTR[6:0]  |                 |         |    |  |  |  |  |  |
| 0X06    | Overflow<br>Counter       |    |                      | _                     |                | OVF_COUNTER[6:0]  |                 |         |    |  |  |  |  |  |
| 0X07    | FIFO Data<br>Counter      |    | FIFO_DATA_COUNT[7:0] |                       |                |                   |                 |         |    |  |  |  |  |  |
| 0X08    | FIFO Data<br>Register     |    |                      |                       | FIFO_I         | DATA[7:0]         |                 |         |    |  |  |  |  |  |
| 0X09    | FIFO Con-<br>figuration 1 |    |                      | _                     |                | FIFO_A_FULL[6:0]  |                 |         |    |  |  |  |  |  |
| 0X0A    | FIFO Con-<br>figuration 2 | _  | _                    | TIME_<br>STAMP_<br>EN | FLUSH_<br>FIFO | FIFO_<br>STAT_CLR | A_FULL_<br>TYPE | FIFO_RO | -  |  |  |  |  |  |

#### Write Pointer (Register 0X04)

FIFO\_WR\_PTR[6:0] points to the FIFO location where the next item will be written. This pointer advances for each item pushed on to the FIFO by the internal conversion process. The write pointer is a 7 bit counter and will wrap around to count 0x00 on the next item after count 0x7F.

#### Read Pointer (Register 0X05)

FIFO\_RD\_PTR[6:0] points to the location from where the next item from the FIFO will be read via the serial interface. This advances each time an item is read from the FIFO. The read pointer can be both read and written to. This allows an item to be reread from the FIFO if it has not already been overwritten. The read pointer is updated from a 7 bit counter and will wrap around to count 0x00 from count 0x7F.

### Overflow Counter (Register 0X06)

OVF\_COUNTER[6:0] logs the number of items lost if the FIFO is not read in a timely fashion. This counter holds/ saturates at count value 0x7F. When a complete item is popped from the FIFO (when the read pointer advances), the OVF\_COUNTER is reset to zero. This counter is essentially a debug tool. It should be read immediately before reading the FIFO in order to check if an overflow condition has occurred.

### FIFO Data Counter (Register 0x07)

FIFO\_DATA\_COUNT[7:0] is a read-only register which holds the number of items available in the FIFO for the host to read. This increments when a new item is pushed to the FIFO, and decrements when the host reads an item from the FIFO.

#### FIFO Data (Register 0X08)

FIFO\_DATA[7:0] is a read-only register used to retrieve data from the FIFO. It is important to burst read the item from the FIFO. Each item is three bytes. So burst reading three bytes at FIFO\_DATA register via the serial interface advances the FIFO\_RD\_PTR. The format and data type of the data stored in the FIFO is determined by the Tag associated with data. Readout from the FIFO follows a progression defined by LED Sequence Control registers as well. This configuration is best illustrated by a few examples.

Assume it is desired to perform a SpO<sub>2</sub> measurement and also monitor the ambient level on the photodiode to adjust the IR and red LED intensity. To perform this measurement, configure the following registers.

```
LED Sequence Control
     LEDC1 = 0x1
                                   (LED1 exposure)
     LEDC2 = 0x2
                                   (LED2 exposure)
     LEDC3 = 0x9
                                   (DIRECT AMBIENT exposure)
     LEDC4 = 0x0
                                   (NONE)
     LEDC5 = 0x0
                                   (NONE)
     LEDC6 = 0x0
                                   (NONE)
PPG Configuration
                                   (PPG1 Gain Range Control)
     PPG1_ADC_RGE[1:0]
     PPG2 ADC RGE[1:0]
                                   (PPG2 Gain Range Control)
     PPG_TINT[1:0]
                                   (LED Pulse Width Control)
     PPG_SR[3:0]
                                   (Sample Rate)
LED Pulse Amplitude
     LED1_PA[7:0]
                                   (LED1 Drive Current)
     LED2 PA[7:0]
                                   (LED2 Drive Current)
```

When done so the sample sequence and the data format in the FIFO will follow the following time/location sequence.

```
tag 1, LED1 data
tag 2, LED2 data
tag 3, Ambient data
tag 1, LED1 data
tag 2, LED2 data
tag 3, Ambient data
.
.
.
tag 1, LED1 data
tag 2, LED2 data
tag 3, Ambient data
```

where:

LED1 data = the ambient corrected exposure data from LED1 LED2 data = the ambient corrected exposure data from LED2

Ambient data = the direct ambient sample

For a second example, assume it is desired to pulse LED1 and LED2 simultaneously while also monitoring the ambient level.

```
      LED Sequence Control
      LEDC1 = 0x4
      (LED1 &LED2 exposure)

      LEDC2 = 0x9
      (DIRECT AMBIENT exposure)

      LEDC3 = 0x0
      (NONE)

      LEDC4 = 0x0
      (NONE)

      LEDC5 = 0x0
      (NONE)

      LEDC6 = 0x0
      (NONE)
```

```
In this case, the sequencing in the FIFO will then be,
     tag 1, LED1+LED2 data
     tag 2, Ambient data
     tag 1, LED1+LED2 data
     tag 2, Ambient data
     tag 1, LED1+LED2 data
     tag 2, Ambient data
  where:
     LED1+LED2 data = the ambient corrected exposure data from LED1 & LED2
     Ambient data = the direct ambient sample
The number of bytes of data for the PPG channel is given by: 3 x K x N
  where:
     K = the number of active exposures as defined in the LED Sequence Control registers 0x20, 0x21 and 0x22.
```

N = the number of samples in the FIFO

To calculate the number of available items one can perform the following pseudo-code:

```
read the OVF COUNTER register
read the FIFO_DATA_COUNT register
if OVF_COUNTER == 0 //no overflow occurred
  NUM_AVAILABLE_SAMPLES = FIFO_DATA_COUNT
else
  NUM AVAILABLE SAMPLES = 128 // overflow occurred and data has been lost
endif
```

Table 6 shows the FIFO data format depends on the data type being stored. Optical data, whether full ambient corrected LED exposure, ambient corrected proximity or direct ambient sampled data is left justified as shown in the table below. Bits F23:F19 of the FIFO word contains the tag that identifies the data. FIFO\_A\_FULL (address 0x09)

**Table 6. Optical FIFO Data Format** 

|             |                                            | FIFO DATA FORMAT (FIFO_DATA[23:0]) |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
|-------------|--------------------------------------------|------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| ADC         | Tag (TAG[4:0]) ADC Value (FIFO_DATA[18:0]) |                                    |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |
| Res         | F23                                        | F22                                | F21 | F20 | F19 | F18 | F17 | F16 | F15 | F14 | F13 | F12 | F11 | F10 | F9 | F8 | F7 | F6 | F5 | F4 | F3 | F2 | F1 | F0 |
| 19-<br>bits | T4                                         | Т3                                 | T2  | T1  | ТО  | O18 | 017 | O16 | O15 | 014 | O13 | 012 | 011 | O10 | 09 | O8 | 07 | O6 | O5 | 04 | О3 | O2 | 01 | 00 |

The FIFO A FULL[6:0] field in the FIFO Configuration 1 register (0x09) sets the watermark for the FIFO and determines when the A FULL bit in the Interrupt Status register (0x00) gets asserted. The A FULL bit will be set when the FIFO contains 128 minus FIFO A FULL[6:0] items. When the FIFO is almost full, if the A FULL EN mask bit in the Interrupt Enable register (0x03) is set, then A FULL bit gets asserted in the Interrupt Status 1 register and this bit is routed to the INT pin on the MAX86140 interface. This condition should prompt the applications processor to read samples off of the FIFO before it fills. The A\_FULL bit is cleared when the status register is read.

The application processor can read both the FIFO\_WR\_PTR and FIFO\_RD\_PTR to calculate the number of items available in the FIFO, or just read the OVF\_COUNTER and FIFO\_DATA\_COUNT registers, and read as many items as it needs to empty the FIFO. Alternatively, if the applications always responds much faster than the selected sample rate, it could just read 128 minus FIFO\_A\_FULL[6:0] items when it gets A\_FULL interrupt and be assured that all data from the FIFO are read.

#### FIFO\_RO (Address 0x0A)

The FIFO\_RO bit in the FIFO Configuration 2 register (0x0A) determines whether samples get pushed on to the FIFO when it is full. If push is enabled when FIFO is full, old samples are lost. If FIFO\_RO is not set, the new sample is dropped and the FIFO is not updated.

#### A\_FULL\_TYPE (Address 0x0A)

The A\_FIFO\_TYPE bit defines the behavior of the A\_FULL interrupt. If the A\_FIFO\_TYPE bit is set low, the A\_FULL interrupt gets asserted when the A\_FULL condition is detected and cleared by status register read, but reasserts for every sample if the A\_FULL condition persists. If A\_FIFO\_TYPE bit is set high, the A\_FULL interrupt gets asserted only when a new A\_FULL condition is detected. The interrupt gets cleared on Interrupt Status 1 register read, and does not re-assert for every sample until a new a-full condition is detected.

#### FIFO\_STAT\_CLR (Address 0x0A)

The FIFO\_STAT\_CLR bit defines whether the A-FULL interrupt should get cleared by FIFO\_DATA register read. If FIFO\_STAT\_CLR is set low, A\_FULL and DATA\_RDY interrupts do not get cleared by FIFO\_DATA register read but get cleared by status register read. If FIFO\_STAT\_CLR is set high, A\_FULL and DATA\_RDY interrupts get cleared by a FIFO\_DATA register read or a status register read.

#### FLUSH FIFO (Address 0x0A)

The FIFO Flush bit is used for flushing the FIFO. The FIFO becomes empty and the FIFO\_WR\_PTR[6:0], FIFO\_RD\_PTR[6:0], FIFO\_DATA\_COUNT[7:0] and OVF\_COUNTER[6:0] get reset to zero. FLUSH\_FIFO is a self-clearing bit.

#### TIME\_STAMP\_EN (Address 0x0A)

When TIME\_STAMP\_EN bit is set to 1, the 19 bits time stamp gets pushed to the FIFO along with its Tag for every 8 samples. This time stamp is useful for aligning data from two devices after the host reads the FIFOs of those devices. When TIME\_STAMP\_EN bit is set to 0, the sample counter is not pushed to FIFO.

### **Optical Timing**

The MAX86140 optical controller is capable of being configured to make a variety of measurements. Each LED exposure is ambient light compensated before the ADC conversion.

The controller can be configured to pulse one, two or three LED drivers sequentially so as to make measurements at multiple wavelengths as is done in a pulse oximetry measurements or simultaneously to drive multiple LEDs such as is done with heart rate measurements on the wrist.

The controller is also configurable to measure direct ambient level for every exposure sample. The direct ambient measurement can be used to adjust the LED drive level to compensate for increased noise levels when high interfering ambient signals are present.

The following optical timing diagrams illustrate several possible measurement configurations.

#### One LED Pulsing with no Direct Ambient Sampling

The optical timing diagram below represents just LED1 pulsing during the exposure time with no direct ambient sampling enabled. This timing mode would be used when heart rate is being measured with a single green LED. In this mode a single optical sampled value will appear successively in the FIFO.

### One LED Pulsing with Direct Ambient Sampling

The optical timing diagram below represents just LED1 pulsing during the exposure time with direct ambient sampling enabled. This timing mode would be used when heart rate is being measured with a single green LED. In this mode a single optical sampled value followed by the ambient sampled value will appear successively in the FIFO.



Figure 1. Timing for LED1 Pulsing with No Direct Ambient Sampling



Figure 2. Timing for LED1 Pulsing with Direct Ambient Sampling

# Two LEDs Pulse Simultaniously with Direct Ambient Sampling

The optical timing diagram below represents both LED1 and LED2 pulsing simultaneously with direct ambient sampling enabled. This timing mode would be used when heart rate is being measured with two green LEDs. In this mode a single optical sampled value followed by the ambient sampled value will appear in successive the FIFO locations. The direct ambient sampling is typically used to compensate the LED drive levels as the optical noise level can be elevated from ambient shot noise.

## All LED Pulsing Simultaniously with Direct Ambient Sampling

The optical timing diagram below represents all three LEDs pulsing simultaneously with direct ambient sampling enabled. This timing mode would be used when heart rate is being measured with three green LEDs. In this mode a single optical sampled value followed by the ambient sampled value will appear in successive the FIFO locations. The direct ambient sampling is typically used to compensate the LED drive levels as the optical noise level can be elevated from ambient shot noise.



Figure 3. Timing for LED1 and LED2 Pulsing Simultaneously with Direct Ambient Sampling



Figure 4. Timing for LED1, LED2, and LED3 Pulsing Simultaneously with Direct Ambient Sampling

# Two LEDs pulse Sequentially with Direct Ambient Sampling

The timing diagram below illustrates the optical timing when both LED1 and LED2 are enabled to pulse sequentially and direct ambient sampling is also enabled. This timing mode would be used when SpO<sub>2</sub> is being measured with IR and red LEDs. The optical sampled value for each LED will appear successively, followed by the direct ambient sampled value in the FIFO. when SpO<sub>2</sub> is being measured with IR and red LEDs. The

optical sampled value for each LED will appear successively, followed by the direct ambient sampled value in the FIFO.

## All LEDs Pulse Sequential with Direct Ambient Sampling

The optical timing diagram below illustrates the three LEDs pulsing sequentially, followed by a direct ambient sample. This timing mode would be used when heart rate on a green LED is combined with and SpO<sub>2</sub> measurement using IR and RED LEDs.



Figure 5. Timing for LED1 and LED2 Pulsing Sequentially with Direct Ambient Sampling



Figure 6. Timing for LED1, LED2 and LED3 Pulsing Sequentially with Direct Ambient Sampling

### **GPIO Configuration**

The MAX86140 supports several means by which it can synchronize to external sensors, muxes and be extended to allow for more flexibility in the measurement configuration. This functionality is extended through the GPIO1 and GPIO2 pins and is selected by the GPIO CTRL bit field in the PPG SYNC Control register (0x10). The following describes option and the functional state of GPIO1 and GPIO2 as well as the part behavior.

### GPIO CTRL[3:0] 0000 and 0001: Stand Along with and without External Mux

Table 7. GPIO Mode 0000 and 0001

| GPIO<br>CTRL | GPIO1<br>FUNCTION          | GPIO2<br>FUNCTION                             | COMMENT                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|----------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000         | Tristate or<br>Mux Control | Disabled                                      | GPIO1 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO1 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO1 will be tristate. GPIO2 is disabled. Sample and exposure timing is controlled by the internal 32768Hz oscillator.  |
| 0001         | Tristate or<br>Mux Control | Input<br>32768Hz or<br>32000Hz<br>Clock Input | GPIO1 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO1 will be high during exposures on LED4, LED5 or LED6; otherwise, it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO1 will be tristate. GPIO2 is an input 32768/32000Hz. Sample and exposure timing is controlled by GPIO2 clock input. |



Figure 7. Block Diagram for GPIO CTRL[3:0] 0000 and 0001 Without External Mux



Figure 8. Timing Diagram for GPIO CTRL[3:0] 0000 and 0001 Without External Mux



Figure 9. Block Diagram for GPIO CTRL[3:0] 0000 and 0001 With External Mux



Figure 10. Timing Diagram for GPIO CTRL[3:0] 0000 and 0001 with External Mux

### GPIO CTRL[3:0] 0010: Start of Sample Input with and without External Mux

### Table 8. GPIO Mode 0010

| GPIO CTRL | GPIO1<br>FUNCTION       | GPIO2 FUNCTION             | COMMENT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|-------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0010      | Input<br>Sample Trigger | Tristate or<br>Mux Control | GPIO1 is defined as a sample trigger input (Slave). This input can come from an external source or from another MAX86140 in master sample mode. GPIO2 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO2 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO2 will be tristate. Exposure timing is controlled by internal oscillator. |



Figure 11. Block Diagram for GPIO CTRL[3:0] 0010 Without External Mux



Figure 12. Timing Diagram for GPIO CTRL[3:0] 0010 Without External Mux



Figure 13. Block Diagram for GPIO CTRL[3:0] 0010 with External Mux



Figure 14. Timing Diagram for GPIO CTRL[3:0] 0010 with External Mux

### GPIO CTRL[3:0] 0011: Start of Sample Input with External Clock

### Table 9. GPIO Mode 0011

| GPIO CTRL | GPIO1<br>FUNCTION       | GPIO2 FUNCTION                             | COMMENT                                                                                                                                                                                                                                          |
|-----------|-------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0011      | Input<br>Sample Trigger | Input<br>32768Hz<br>or 32000Hz Clock Input | GPIO1 is defined as a sample trigger input (Slave). This input can come from an external source or from another MAX86140 in master sample mode. GPIO2 is an input 32768/32000Hz clock input. Exposure timing is controlled by GPIO2 clock input. |



Figure 15. Block Diagram for GPIO CTRL[3:0] 0011



Figure 16. Timing Diagram for GPIO CTRL[3:0] 0011

### GPIO CTRL[3:0] 0100: Start of Sample Output with and without External Mux

### Table 10. GPIO Mode 0100

| GPIO CTRL | GPIO1<br>FUNCTION                     | <b>GPIO2 FUNCTION</b>      | COMMENT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|---------------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0100      | Active Output<br>Master Sample Output | Tristate or<br>Mux Control | GPIO1 is defined as a master sample output. The GPIO1 output can be used to trigger a second sensor. When used with a second MAX86140 set to slave sample mode, the master sample timing will drive slave sample time. GPIO2 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO2 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO2 will be tristate. Sample and exposure timing is controlled by internal oscillator. |



Figure 17. Block Diagram for GPIO CTRL[3:0] 0100 Without External Mux



Figure 18. Timing Diagram for GPIO CTRL[3:0] 0100 Without External Mux



Figure 19. Block Diagram for GPIO CTRL[3:0] 0100 with External Mux



Figure 20. Timing Diagram for GPIO CTRL[3:0] 0100 with External Mux

### GPIO CTRL[3:0] 0101: Start of Sample Output with RTC Input Clock

Table 11. GPIO Mode 0101

| GPIO CTRL | GPIO1<br>FUNCTION                     | GPIO2 FUNCTION                     | COMMENT                                                                                                                                                                                                                                                                                                     |
|-----------|---------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0101      | Active Output<br>Master Sample Output | Input<br>32768/32000Hz Clock Input | GPIO1 is defined as a master sample output. The GPIO1 output can be used to trigger a second sensor. When used with a second MAX86140 set to slave sample mode, the master sample timing will drive slave sample time. GPIO2 is an input 32768/32000Hz. Exposure timing is controlled by GPIO2 clock input. |



Figure 21. Block Diagram for GPIO CTRL[3:0] 0101



Figure 22. Timing Diagram for GPIO CTRL[3:0] 0101

### GPIO CTRL[3:0] 0110 and 0111: Master/Slave with External Mux

### Table 12. GPIO Mode 0110 and 0111

| GPIO<br>CTRL | GPIO1<br>FUNCTION                                | GPIO2<br>FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | COMMENT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0110         | Input<br>Exposure<br>Trigger                     | Tristate or<br>Mux Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | GPIO1 is defined as an exposure trigger input (Slave). This input can come from an external source or from another MAX86140 in master sample mode. Both sample and exposure timing is controlled by the GPIO1 input. GPIO2 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO2 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO2 will be tristate. |
| 0111         | Active<br>Output<br>Master<br>Exposure<br>Output | Tristate or Mux Control  Tristate or Mux Control  Tristate or Mux Control  Mux Control  Mux Control  Tristate or Mux Control  Mux Contr |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |



Figure 23. Block Diagram for GPIO CTRL[3:0] 0110 and 0111 with A Single External Mux



Figure 24. Block Diagram for GPIO CTRL[3:0] 0110 and 0111 With Two External Muxes



Figure 25. Timing Diagram for GPIO CTRL[3:0] 0110 and 0111 With External Mux

### GPIO CTRL[3:0] 0110 and 1000: Master/Slave with and without External Mux

### **Table 13. GPIO Mode 0110 and 1000**

| GPIO<br>CTRL | GPIO1<br>FUNCTION                    | GPIO2<br>FUNCTION                     | COMMENT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|--------------------------------------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0110         | Input<br>Exposure<br>Trigger         | Tristate or<br>Mux Control            | GPIO1 is defined as an exposure trigger input (Slave). This input can come from an external source or from another MAX86140 in master sample mode. Both sample and exposure timing is controlled by the GPIO1 input. GPIO2 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO2 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO2 will be tristate. |
| 1000         | Active Output Master Exposure Output | Input<br>32768/32000Hz<br>Clock Input | GPIO1 is defined as a master sample output. The GPIO1 output can be used to trigger and second sensor. When used with a second MAX86140 set to slave exposure mode, the master exposure timing will drive slave exposure time. GPIO2 is an input 32768/32000Hz. Sample and exposure timing is controlled by GPIO2 clock input.                                                                                                                                                                                                |



Figure 26. Block Diagram for GPIO CTRL[3:0] 0110 and 1000 Without External Mux



Figure 27. Timing Diagram for GPIO CTRL[3:0] 0110 and 1000 Without External Mux



Figure 28. Block Diagram for GPIO CTRL[3:0] 0110 and 1000 With External Mux



Figure 29. Timing Diagram for GPIO CTRL[3:0] 0110 and 1000 With External Mux

#### GPIO CTRL[3:0] 1001 Hardware Sync

#### Table 14. GPIO Mode 1001

| GPIO | GPIO1                      | GPIO2                                         | COMMENT                                                                                                                                                                                                                                                                                |
|------|----------------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CTRL | FUNCTION                   | FUNCTION                                      |                                                                                                                                                                                                                                                                                        |
| 1001 | Input<br>HW_FORCE_<br>SYNC | Input<br>32768Hz<br>or 32000Hz<br>Clock Input | GPIO1 is defined as a start of sample sync input. The rising edge of GPIO1 causes the present sample sequence to be terminated and reinitiated on the next rising edge of GPIO2 input. GPIO2 is an input 32768/32000Hz. Sample and exposure timing is controlled by GPIO2 clock input. |

#### **Proximity Mode Function**

The MAX86140 includes an optical proximity function which could significantly reduce energy consumption and extend battery life when the sensor is not in contact with the skin. Proximity mode is enabled by setting PROX\_INT\_EN bit field to 1 in the Interrupt Enable 2 register (address 0x02[4]), setting a threshold in the PROX\_INT\_THRESH register (address 0x14) and assigning an LED current in the PILOT\_PA (address 0x29). Proximity mode also requires that LED Sequence Register 1, field LEDC1 (address [3:0]) to be assigned to a specific measurement and that measurement is correctly connected to a light source. The LEDC1 measurement is used to detect the optical presents of a reflecting object in proximity mode and thus must be valid for proximity mode to work.

When enabled, the Proximity Detect Interrupt (register 0x01[4]) will be asserted and proximity mode will be entered when the value of the measurement assigned to LEDC1 drops below the PROX\_INT\_THRESH. When entering proximity mode, the MAX86140 will drop the current to the LED(s) assigned to LEDC1 to PILOT\_PA value, reduce the sample rate to 8sps and operates in Low Power mode. The intent here is to both reduce the consumed LED current and MAX86140 power to a minimum during situations where there is no reflective returned signal. It is also intended to reduce the emitted light to a minimum or even below that perceivable by the human eye.

When the proximity mode is enabled and the measurement assigned to LEDC1 with the LED current in PILOT\_

PA exceeds the PROX\_INT\_THRESH, the MAX86140 will also generate a Proximity Detect Interrupt (register 0x01[4]). In such an event MAX86140 will switch to normal mode, changing the sample rate to that assigned in PPG Configuration 2 register (address 0x12) bit field PPG\_SR and the LED current assigned to the measurement of LEDC1. Thus the MAX86140 is able to switch to proximity mode and back to normal mode without microprocessor interaction.

The threshold applied to PROX\_INT\_THRESH should be well below that of a usable signal at the maximum LED current applied to LEDC1 but high enough to not be triggered by noise from distant objects. Further the current assigned to PILOT\_PA should be much lower than that assigned to LEDx\_PA in normal mode. This will ensure that the signal obtained from LEDC1 will drop significantly when entering proximity mode, thus providing enough hysteresis to eliminate multiple interrupts being generated at the proximity/normal mode transition.

To guarantee that MAX86140 will successfully transition from proximity mode to normal mode, the PROX\_INT\_THRESH should be low enough and the PILOT\_PA high enough to ensure that the device mounted on the darkest of skins will return a signal above the PROX\_INT\_THRESH at the PILOT\_PA current.

Note that proximity mode is only available to LEDC1 measurements that are made with PD1\_IN optical channel without an external mux. When proximity mode is active, LEDC2~LEDC6 will be ignored. The threshold applied to PROX\_INT\_THRESH register are in units of 2048LSBs.



Figure 30. Proximity Function Flow Diagram

#### **Picket Fence Detect-and-Replace Function**

Under typical situations, the rate of change of ambient light is such that the ambient signal level during exposure can be accurately predicted and high levels of ambient rejection are obtained. However, it is possible to have situations where the ambient light level changes extremely rapidly, for example when in a car with direct sunlight exposure passes under a bridge and into a dark shadow. In these situations, it is possible for the MAX86140 ambient light correction (ALC) circuit to fail and produce and erroneous estimation of the ambient light during the exposure interval. The MAX86140 has a built-in algorithm, call the picket fence function, that can correct for these extreme conditions resultant failure of the ALC circuit.

The picket fence function works on the basis that the extreme conditions causing a failure of the ALC are rare events. These events resulting in a large deviation from the past sample history of a normal PPG riding on a motion effect signal, which normally would change relatively slowly with respect to the sampling interval. Under these conditions, it is possible to detect sample values that are well outside the normal sample to sample deviation and replace those samples with an extrapolated value based on the relatively recent history of samples.

The picket fence function is enabled by setting PF\_ENABLE (address 0x16[7]) bit to 1. The power on reset default of MAX86140 has the picket fence function disabled. The function begins with detecting a picket fence event. Detection is done by taking the absolute value of the difference between the present ADC converted value a predicted point, called an estimation error, and comparing this estimation error to a threshold. If the estimation error exceeds the threshold, then the present ADC converted point is considered a picket fence event.

The predicted point referred to above is computed in one of two ways, set by the value in the PF\_ORDER (address 0x16[6]) bit. If PF\_ORDER = 0 the predicted point is

simply the previous ADC converted point. If PF\_ORDER = 1 the predicted point is a least square fit extrapolation based on the previous four picket fence outputs, which under normal circumstances is identical to the ADC converted inputs.

The threshold used in detecting a picket fence event is a low passed version of the running estimation error computed above times a multiplier. The multiplier used is set by the THRESHOLD\_SIGMA\_MULT (address 0x16[1:0]) bits and can be 4, 8, 16, or 32 times the running low-passed filter output of the estimation error.

The low pass filter function is controlled by two parameters, the IIR\_TC (address 0x16[5:4]) bits and IIR\_INIT\_ VALUE (address 0x16[3:2]) bits. The IIR\_TC bits control the filters time constant and are adjustable from 8 to 64 samples. The IIR\_INIT\_VALUE bits control the initial values for the IIR low pass filter when the algorithm is initialized.

When a picket fence event is detected, the option of how to extrapolate the correct point is again controlled by the PF\_ORDER bit. This point can be identical as the previous point (PF\_ORDER = 0) or a least square fit extrapolation based on the previous four ADC converted points (PF\_ORDER = 1).

Figure 31 below illustrates the function in block diagram form. If the picket fence algorithm is enabled (bit PF\_ENABLE =1), the input from the ADC, s(n) generates p(n) in a way that is dependent on the value of the PF\_ORDER bit. Value s(n) is subtracted from p(n) and turned into a positive number d(n) and fed into the IIR low pass filter producing value lpf(n). The output of the low pass filter lpf(n) is then multiplied by a user constant, THRESHOLD\_SIGMA\_MULT to produce the picket fence threshold, PFT(n). The value d(n) is then compared to this threshold and if greater than the PFT(n), the point s(n) is replaced with the point p(n).



Figure 31. Picket Fence Function Flow

#### MAX86140

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor for Wearable Health

This scheme essentially produces a threshold that tracks the past returned optical signal with a band width based on the past historical change sample to sample. Figure 32 below illustrates graphically how the threshold detection scheme works on a real PPG signal. Note that the black

trace is the real ADC sample points, the red traces are the output of the low pass filter of the error estimation mirrored around the ADC points and the blue traces are the threshold values.



Figure 32. Picket Fences Variables In A PPG Waveform

The recommended settings for the picket fence algorithm are the default power on reset values for all registers but THRESHOLD\_SIGMA\_MULT bits. Here it is recommended that the 32x value 0x3 be used so only large excursions are classified as picket fence events. Lower values of THRESHOLD\_SIGMA\_MULT can cause the algorithm to go off track with extremely noisy waveform.

#### **Photo Diode Biasing**

The MAX86140 provides multiple photo diode biasing options. These options allow the MAX86140 to operate with a large range of photo diode capacitance. The PDBIAS values adjust the PD\_IN bias point impedance to ensure that the photo diode settles rapidly enough to support the sample timing.

As the PDBIAS values goes up, the input referred noise of the MAX86140 goes up. The relationship between PDBIAS and noise with increasing photo diode capacitance is illustrated in the "Input Referred Noise vs. PD Capacitance" graph of the Typical Operating Characteristics section. Because of the increased noise with PDBIAS, the lowest recommended PDBIAS values should be used for a give photo diode capacitance.

#### **Layout Guidelines**

MAX86140 is a high dynamic range analog front-end (AFE) and its performance can be adversely impacted by the physical printed circuit board (PCB) layout. It is recommended that all bypass recommendation in the pin table be followed. Specifically, it is recommended that the VDD\_ANA and VDD\_DIG pins be shorted at the PCB. It is also recommended that GND\_ANA, GND\_DIG and PGND be shorted to a single PCB GND plane. These three pins have been assigned along a single column so they can be shorted and combined into a single via on the edge of the WLP grid array.

The combined VDD\_ANA and VDD\_DIG pins should then be decoupled with a 0.1uF or larger ceramic chip capacitor to the PCB GND plane. In addition, the VREF pin should be decoupled to the PCB GND plane with a  $1.0\mu F$  ceramic capacitor. The voltage on the VREF pin is nominally 1.21V, so a 6.3V rated ceramic capacitor should be adequate for this purpose. It is recommended at all decoupling caps use individual vias to the PCB GND plane to avoid mutual impedance coupling between decoupled supplies when sharing vias.

The most critical aspect of the PCB layout of MAX86140 is the handling of the PD IN and PD GND nodes. Parasitic capacitive coupling to the PD IN can result in additional noise being injected into the MAX86140 frontend. To minimize external interference coupling to PD IN, it is recommended that the PD IN node be fully shielded by the PD GND node. An example of this recommendation is shown below. In the three layers shown, the PD IN node is shielded with a coplanar PD\_GND trace on the top layer, the layer on which the MAX86140 is mounted. On the bottom layer, the photo diode cathode is entirely shielded with the PD\_GND shield, which is also the photo diode anode. Note also that the PD GND shield also is extended below the photo diode. This is done because in most photo diodes, the cathode is the bulk of the silicon. Thus, shielding beneath the photo diode will terminate the capacitance to the bulk or cathode side to the reference node, PD GND. On the layer just above the bottom (layer 5 in this case) the section of the GND plane has been opened up, connected to PD GND to shield the PD IN node below the photo diode cathode contact. Finally, the PD GND pin should only be attached to the PCB GND in only one point. This is shown on the top layer.

Table 15. Recommended PDBIAS Values Based on the Photo Diode Capacitance

| PDBIAS<2:0>      | PHOTO DIODE CAPACITANCE |
|------------------|-------------------------|
| 0x001            | 0pF to 65pF             |
| 0x101            | 65pF to 130pF           |
| 0x110            | 130pF to 260pF          |
| 0x111            | 260pF to 520pF          |
| All other values | Not recommended         |



Figure 33. Example PCB Layout, Layer 1 (Top, MAX86140)



Figure 34. Example PCB Layout, Layer 6 (Bottom, Optical Layer)



Figure 35. Example PCB Layout, Layer5 (Ground Layer)

#### **SPI Timing**

#### **Detailed SPI Timing**

The detailed SPI timing is illustrated below. The timings indicated are all specified in the *Electrical Characteristics* table above.

#### Single Word SPI Register Read/Write Transaction

The MAX86140 is SPI/QSPI/Micro-wire/DSP compatible. The operation of the SPI interface is shown below. Data is strobed into the MAX86140 on SCLK rising edge while clocked out on the SCLK falling edge. All single word SPI read and write operations are done in a 3 byte, 24 clock cycle SPI instruction framed by a CSB low

interval. The content of the SPI operation consists of a one byte register address, A[7:0], followed by a one byte command word which defines the transaction as write or read, followed by a single byte data word either written to or read from the register location provided in the first byte. Write mode operations will be executed on the 24<sup>th</sup> SCLK rising edge using the first three bytes of data available. In write mode, any data supplied after the 24th SCLK rising edge will be ignored. Subsequent writes require CSB to deassert high and then assert low for the next write command. A rising CSB edge preceding the 24th rising edge of SCLK by tCSA (detailed SPI timing diagram), will result in the transaction being aborted.



Figure 36. Detailed SPI Timing Diagram



Figure 37. SPI Write Transaction

Read mode operations will access the requested data on the 16th SCLK rising edge, and present the MSB of the requested data on the following SCLK falling edge, allowing the  $\mu$ C to latch the data MSB on the 17th SCLK rising edge. Configuration and status registers are available via normal mode read back sequences. FIFO reads must be done with a burst mode FIFO read (see next section). If more than 24 SCLK rising edges are provided in a normal read sequence then the excess edges will be ignored and the device will read back zeros.

#### **SPI FIFO Burst Mode Read Transaction**

The MAX86140 provides a FIFO burst read mode to increase data transfer efficiency. The first 16 SCLK cycles operate exactly as described for the normal read mode,

the first byte being the register address, the second being a read command. The subsequent SCLKs consist of FIFO data, 24 SCLKs per word. All words in the FIFO should be read with a single FIFO burst read command.

Each FIFO sample consists of 3 bytes per sample and thus requires 24 SCLKs per sample to readout. The first byte (SCLK 16 to 23) consists of a tag indicating the data type of the subsequent bits. Following the tag is the MSBs of the subsequent data (MSB, MSB-1 and MSB-2). The next byte (SCLK 24 to 31) consists of data bits MSB-3 to MSB-19. The final byte of each sample (SCLK 32 to 40) consists of the data LSB bits. The number of words in the FIFO depends on the FIFO configuration. Please see the FIFO configuration section for more details the FIFO configuration and readout.



Figure 38. SPI Read Transaction



Figure 39. SPI FIFO Burst Mode Read Transaction

### **Register Map**

### **User Register Map**

| ADDRESS     | NAME                               | MSB                   |                 |                      |                       |                       |                         |                | LSB                 |
|-------------|------------------------------------|-----------------------|-----------------|----------------------|-----------------------|-----------------------|-------------------------|----------------|---------------------|
| Status      | IVANIE                             | IVIOD                 |                 |                      |                       |                       |                         |                | LOD                 |
| 0x00        | Interrupt Status 1[7:0]            | A_FULL                | DATA_<br>RDY    | ALC_<br>OVF          | PROX_<br>INT          | LED_<br>COMPB         | DIE_<br>TEMP_<br>RDY    | VDD_<br>OOR    | PWR_<br>RDY         |
| 0x01        | Interrupt Status 2[7:0]            | _                     | _               | _                    | _                     | _                     | _                       | _              | SHA_<br>DONE        |
| 0x02        | Interrupt Enable 1[7:0]            | A_FULL_<br>EN         | DATA_<br>RDY_EN | ALC_<br>OVF_EN       | PROX_<br>INT_EN       | LED_<br>COMPB_<br>EN  | DIE_<br>TEMP_<br>RDY_EN | VDD_<br>OOR_EN | -                   |
| 0x03        | Interrupt Enable 2[7:0]            | _                     | _               | _                    | _                     | _                     | _                       | _              | SHA_<br>DONE_<br>EN |
| FIFO        |                                    |                       |                 |                      |                       |                       |                         |                |                     |
| 0x04        | FIFO Write Pointer[7:0]            | _                     |                 |                      | FIF                   | D_WR_PTR              | [6:0]                   |                |                     |
| 0x05        | FIFO Read Pointer[7:0]             | _                     |                 |                      | FIF                   | O_RD_PTR              | [6:0]                   |                |                     |
| 0x06        | Over Flow Counter[7:0]             | _                     |                 |                      | OVF                   | _COUNTER              | R[6:0]                  |                |                     |
| 0x07        | FIFO Data Coun-<br>ter[7:0]        |                       |                 | F                    | IFO_DATA              | _COUNT[7:0            | 0]                      |                |                     |
| 0x08        | FIFO Data Regis-<br>ter[7:0]       |                       |                 |                      | FIFO_D                | ATA[7:0]              |                         |                |                     |
| 0x09        | FIFO Configuration 1[7:0]          | -                     |                 |                      | FIF                   | O_A_FULL[             | 6:0]                    |                |                     |
| 0x0A        | FIFO Configuration 2[7:0]          | _                     | _               | _                    | FLUSH_<br>FIFO        | FIFO_<br>STAT_<br>CLR | A_FULL_<br>TYPE         | FIFO_<br>RO    | -                   |
| System Cont | rol                                |                       |                 |                      |                       |                       |                         |                |                     |
| 0x0D        | System Control[7:0]                | _                     | _               | _                    | _                     | _                     | LP_<br>MODE             | SHDN           | RESET               |
| PPG Configu | ration                             |                       |                 |                      |                       |                       |                         |                |                     |
| 0x10        | PPG Sync Control[7:0]              | TIME_<br>STAMP_<br>EN | _               | _                    | SW_<br>FORCE_<br>SYNC |                       | GPIO_CTRL[3:0]          |                |                     |
| 0x11        | PPG Configuration<br>1[7:0]        | ALC_<br>DISABLE       | ADD_<br>OFFSET  | _                    | _                     | PPG1_<br>RGE          | _ADC_<br>[[1:0]         | PPG_T          | NT[1:0]             |
| 0x12        | PPG Configuration 2[7:0]           | PPG_SR[4:0] SMP_AVE[2 |                 |                      |                       | MP_AVE[2:             | 0]                      |                |                     |
| 0x13        | PPG Configuration 3[7:0]           | LED_SET               | ΓLNG[1:0]       | DIG_<br>FILT_<br>SEL | _                     | _                     | BURST_I                 | RATE[1:0]      | BURST_<br>EN        |
| 0x14        | Prox Interrupt Thresh-<br>old[7:0] |                       |                 | Р                    | ROX_INT_              | THRESH[7:             | 0]                      |                |                     |
| 0x15        | Photo Diode Bias[7:0]              | _                     | _               | _                    | _                     | _                     | F                       | PDBIAS1[2:0    | )]                  |
| -           | ·                                  |                       |                 |                      |                       |                       |                         |                |                     |

### **Register Map (continued)**

| ADDRESS      | NAME                         | MSB                          |               |                   |          |            |            |        | LSB                  |
|--------------|------------------------------|------------------------------|---------------|-------------------|----------|------------|------------|--------|----------------------|
| PPG Picket F | ence Detect and Replac       | e                            |               |                   |          |            |            |        |                      |
| 0x16         | Picket Fence[7:0]            | PF_EN-<br>ABLE               | PF_OR-<br>DER | IIR_T             | C[1:0]   | IIR_INIT_\ | /ALUE[1:0] |        | OLD_SIG-<br>ULT[1:0] |
| LED Sequen   | ce Control                   |                              |               |                   |          |            |            |        |                      |
| 0x20         | LED Sequence Register 1[7:0] |                              | LEDC          | 2[3:0]            |          |            | LEDC       | 1[3:0] |                      |
| 0x21         | LED Sequence Register 2[7:0] |                              | LEDC          | 4[3:0]            |          |            | LEDC       | 3[3:0] |                      |
| 0x22         | LED Sequence Register 3[7:0] |                              | LEDC          | 6[3:0]            |          |            | LEDC       | 5[3:0] |                      |
| LED Pulse A  | mplitude                     |                              |               |                   |          |            |            |        |                      |
| 0x23         | LED1 PA[7:0]                 |                              |               |                   | LED1_    | DRV[7:0]   |            |        |                      |
| 0x24         | LED2 PA[7:0]                 |                              |               |                   | LED2_    | DRV[7:0]   |            |        |                      |
| 0x25         | LED3_PA[7:0]                 |                              |               |                   | LED3_    | DRV[7:0]   |            |        |                      |
| 0x26         | LED4 PA[7:0]                 |                              |               |                   | LED4_    | DRV[7:0]   |            |        |                      |
| 0x27         | LED5 PA[7:0]                 |                              |               |                   | LED5_    | DRV[7:0]   |            |        |                      |
| 0x28         | LED6 PA[7:0]                 |                              |               |                   | LED6_    | DRV[7:0]   |            |        |                      |
| 0x29         | LED PILOT PA[7:0]            |                              |               |                   | PILOT    | _PA[7:0]   |            |        |                      |
| 0x2A         | LED Range 1[7:0]             | _                            | _             | LED3_F            | RGE[1:0] | LED2_F     | RGE[1:0]   | LED1_F | RGE[1:0]             |
| 0x2B         | LED Range 2[7:0]             | _                            | _             | LED6_F            | RGE[1:0] | LED5_F     | RGE[1:0]   | LED4_F | RGE[1:0]             |
| PPG1_HI_RE   | S_DAC                        |                              |               |                   |          |            |            |        |                      |
| 0x2C         | S1 HI RES DAC1[7:0]          | S1_<br>HRES_<br>DAC1_<br>OVR | _             | S1_HRES_DAC1[5:0] |          |            |            |        |                      |
| 0x2D         | S2 HI RES DAC1[7:0]          | S2_<br>HRES_<br>DAC1_<br>OVR | _             | S2_HRES_DAC1[5:0] |          |            |            |        |                      |
| 0x2E         | S3 HI RES DAC1[7:0]          | S3_<br>HRES_<br>DAC1_<br>OVR | -             | S3_HRES_DAC1[5:0] |          |            |            |        |                      |

### **Register Map (continued)**

| ADDRESS      | NAME                               | MSB                          |   |                   |       |         |            |               | LSB           |
|--------------|------------------------------------|------------------------------|---|-------------------|-------|---------|------------|---------------|---------------|
| 0x2F         | S4 HI RES DAC1[7:0]                | S4_<br>HRES_<br>DAC1_<br>OVR | _ |                   |       | S4_HRES | _DAC1[5:0] |               |               |
| 0x30         | S5 HI RES DAC1[7:0]                | S5_<br>HRES_<br>DAC1_<br>OVR | - | S5_HRES_DAC1[5:0] |       |         |            |               |               |
| 0x31         | S6 HI RES DAC1[7:0]                | S6_<br>HRES_<br>DAC1_<br>OVR | _ |                   |       | S6_HRES | _DAC1[5:0] |               |               |
| Die Temperat | Die Temperature                    |                              |   |                   |       |         |            |               |               |
| 0x40         | Die Temperature Configuration[7:0] | -                            | _ | _                 | _     | _       | _          | _             | TEMP_<br>EN   |
| 0x41         | Die Temperature Integer[7:0]       | TEMP_INT[7:0]                |   |                   |       |         |            |               |               |
| 0x42         | Die Temperature Fraction[7:0]      | -                            | _ | _                 | _     |         | TEMP_F     | RAC[3:0]      |               |
| SHA256       |                                    |                              |   |                   |       |         |            |               |               |
| 0xF0         | SHA Command[7:0]                   |                              |   |                   | SHA_C | MD[7:0] |            |               |               |
| 0xF1         | SHA Configuration[7:0]             | -                            | _ | _                 | _     | _       | _          | SHA_EN        | SHA_<br>START |
| Memory       |                                    |                              |   |                   |       |         |            |               |               |
| 0xF2         | Memory Control[7:0]                | -                            | _ | _                 | _     | _       | _          | MEM_<br>WR_EN | BANK_<br>SEL  |
| 0xF3         | Memory Index[7:0]                  | MEM_IDX[7:0]                 |   |                   |       |         |            |               |               |
| 0xF4         | Memory Data[7:0]                   | MEM_DATA[7:0]                |   |                   |       |         |            |               |               |
| Part ID      |                                    |                              |   |                   |       |         |            |               |               |
| 0xFE         | Revision ID[7:0]                   |                              |   |                   | _     |         |            |               |               |
| 0xFF         | Part ID[7:0]                       |                              |   |                   | PART_ | ID[7:0] |            |               |               |

#### Interrupt Status 1 (0x00)

| BIT         | 7         | 6         | 5         | 4         | 3             | 2                | 1         | 0         |
|-------------|-----------|-----------|-----------|-----------|---------------|------------------|-----------|-----------|
| Field       | A_FULL    | DATA_RDY  | ALC_OVF   | PROX_INT  | LED_<br>COMPB | DIE_TEMP_<br>RDY | VDD_OOR   | PWR_RDY   |
| Reset       | 0x0       | 0x0       | 0x0       | 0x0       | 0x0           | 0x0              | 0x0       | 0x0       |
| Access Type | Read Only     | Read Only        | Read Only | Read Only |

#### A\_FULL

This is a read-only bit. This bit is cleared when the Interrupt Status 1 Register is read. It is also cleared when FIFO\_DATA register is read, if FIFO\_STAT\_CLR = 1.

| VALUE | ENUMERATION | DECODE                                                                                                 |
|-------|-------------|--------------------------------------------------------------------------------------------------------|
| 0     | OFF         | Normal Operation                                                                                       |
| 1     | ON          | Indicates that the FIFO buffer will overflow the threshold set by FIFO_A_FULL[6:0] on the next sample. |

#### DATA\_RDY

This is a read-only bit and it is cleared by reading the Interrupt Status 1 register (0x00). It is also cleared by reading the FIFO\_DATA register if FIFO\_STAT\_CLR = 1

| VALUE | ENUMERATION | DECODE                                                        |
|-------|-------------|---------------------------------------------------------------|
| 0     | OFF         | Normal Operation                                              |
| 1     | ON          | This interrupt triggers when there is a new data in the FIFO. |

#### ALC\_OVF

This is a read-only bit. The interrupt is cleared by reading the Interrupt Status 1 register (0x00).

| VALUE | ENUMERATION | DECODE                                                                                                                                                                                                 |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | OFF         | Normal Operation                                                                                                                                                                                       |
| 1     | ON          | This interrupt triggers when the ambient light cancellation function of the photodiode has reached its maximum limit due to overflow, and therefore, ambient light is affecting the output of the ADC. |

#### PROX\_INT

| VALUE | ENUMERATION | DECODE                                                                                                                                                                                                                                                                                                                |
|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | OFF         | Normal Operation                                                                                                                                                                                                                                                                                                      |
| 1     | ON          | Indicates that the ADC reading of the LED configured in LEDC1 has crossed the proximity threshold.  If PROX_INT_EN is 0, then the prox mode is disabled and the exposure sequence configured in LED Sequence Control Registers begins immediately.  This bit is cleared when the Interrupt Status 1 Register is read. |

#### LED\_COMPB

LED is not compliant. At the end of each sample, if the LED Driver is not compliant, LED\_COMPB interrupt is asserted if LED\_COMPB\_EN is set to 1. It is a read-only bit and is cleared when the status register is read.

| VALUE | ENUMERATION   | DECODE                      |
|-------|---------------|-----------------------------|
| 0     | COMPLIANT     | LED driver is compliant     |
| 1     | NOT_COMPLIANT | LED driver is not compliant |

#### DIE\_TEMP\_RDY

This is a read-only bit and it is automatically cleared when the Temperature data is read or when the Interrupt Status 1 Register is read.

| VALUE | ENUMERATION | DECODE                                                            |
|-------|-------------|-------------------------------------------------------------------|
| 0     | OFF         | Normal Operation                                                  |
| 1     | ON          | Indicates that the TEMP ADC has finished it's current conversion. |

#### VDD\_OOR

This is a read-only bit. It is automatically cleared when the Interrupt Status 1 register is read.

The detection circuitry has a 10ms delay time, and will continue to trigger as long as the VDD\_ANA is out of range.

| VALUE | ENUMERATION | DECODE                                                           |
|-------|-------------|------------------------------------------------------------------|
| 0     | OFF         | Normal operation                                                 |
| 1     | ON          | Indicates that VDD_ANA is greater than 2.05V or less than 1.65V. |

#### **PWR RDY**

This is a read-only bit and it indicates that VDD had gone below UVLO Threshold. This bit is not triggered by a soft reset. This bit is cleared when Interrupt Status 1 Register is read, or by setting SHDN bit to 1.

| VALUE | ENUMERATION | DECODE                                              |
|-------|-------------|-----------------------------------------------------|
| 0     | OFF         | Normal Operation                                    |
| 1     | ON          | Indicates that VBATT went below the UVLO threshold. |

#### Interrupt Status 2 (0x01)

| BIT         | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------------|---|---|---|---|---|---|---|-----------|
| Field       | _ | _ | _ | _ | - | _ | _ | SHA_DONE  |
| Reset       | - | - | - | - | - | - | - | 0x0       |
| Access Type | _ | _ | _ | _ | - | _ | _ | Read Only |

#### SHA\_DONE

SHA256 Authentication Done status bit is set to 1 when the Authentication Algorithm completes. This is a read-only bit and it gets cleared when the Status Register is read.

| VALUE | ENUMERATION | DECODE                      |
|-------|-------------|-----------------------------|
| 0x0   |             | SHA Authentication not done |
| 0x1   |             | SHA Authentication done     |

#### **Interrupt Enable 1 (0x02)**

| BIT         | 7           | 6               | 5              | 4               | 3                | 2                   | 1              | 0 |
|-------------|-------------|-----------------|----------------|-----------------|------------------|---------------------|----------------|---|
| Field       | A_FULL_EN   | DATA_<br>RDY_EN | ALC_OVF_<br>EN | PROX_INT_<br>EN | LED_<br>COMPB_EN | DIE_TEMP_<br>RDY_EN | VDD_OOR_<br>EN | - |
| Reset       | 0x0         | 0x0             | 0x0            | 0x0             | 0x0              | 0x0                 | 0x0            | - |
| Access Type | Write, Read | Write, Read     | Write, Read    | Write, Read     | Write, Read      | Write, Read         | Write, Read    | _ |

#### A\_FULL\_EN

| VALUE | ENUMERATION | DECODE                       |
|-------|-------------|------------------------------|
| 0     | OFF         | A_FULL interrupt is disabled |
| 1     | ON          | A_FULL interrupt in enabled  |

| VALUE | ENUMERATION | DECODE                         |
|-------|-------------|--------------------------------|
| 0     | OFF         | DATA_RDY interrupt is disabled |
| 1     | ON          | DATA_RDY interrupt is enabled. |

#### DATA\_RDY\_EN

| VALUE | ENUMERATION | DECODE                        |
|-------|-------------|-------------------------------|
| 0     | OFF         | ALC_OVF interrupt is disabled |
| 1     | ON          | ALC_OVF interrupt in enabled  |

### ALC\_OVF\_EN PROX\_INT\_EN

When this is enabled, the exposure programmed in the LEDC1 Sequence register is used for proximity detection. If the ADC reading for this exposure is below 2048 times the threshold programmed in PROX\_INT\_THRESH register, the device is in proximity mode, otherwise it is in normal mode.

When the device is in proximity mode, the sample rate used is 8 Hz, and the device starts data acquisition in pilot mode, using only one exposure of the LED programmed in LEDC1 register, and the LED current programmed in PILOT\_PA register.

When the device is in normal mode, the sample rate used is as defined under PPG\_SR register, and the device starts data acquisition in normal mode, using all the exposures programmed in the LED Sequence registers and appropriate LED currents.

PROX\_INT interrupt is asserted when the devices enters proximity mode or normal mode if PROX\_INT\_EN is pro-

| VALUE | ENUMERATION | DECODE                                             |
|-------|-------------|----------------------------------------------------|
| 0     | OFF         | Proximity mode and PROX_INT interrupt are disabled |
| 1     | ON          | Proximity mode and PROX_INT interrupt are enabled  |

#### grammed to 1.

| VALUE | ENUMERATION | DECODE                          |
|-------|-------------|---------------------------------|
| 0     | DISABLE     | LED_COMPB interrupt is disabled |
| 1     | ENABLE      | LED_COMPB interrupt is enabled  |

#### LED\_COMPB\_EN

| VALUE | ENUMERATION | DECODE                             |
|-------|-------------|------------------------------------|
| 0     | OFF         | DIE_TEMP_RDY interrupt is disabled |
| 1     | ON          | DIE_TEMP_RDY interrupt is enabled  |

### DIE\_TEMP\_RDY\_EN

| VALUE | ENUMERATION | DECODE                         |
|-------|-------------|--------------------------------|
| 0     | OFF         | Disables the VDD_OVR interrupt |
| 1     | ON          | Enables the VDD_OVR interrupt  |

### VDD\_OOR\_EN

| BIT         | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0               |
|-------------|---|---|---|---|---|---|---|-----------------|
| Field       | - | _ | _ | _ | _ | - | - | SHA_<br>DONE_EN |
| Reset       | _ | _ | _ | _ | _ | - | _ | 0x0             |
| Access Type | - | _ | _ | _ | - | - | - | Write, Read     |

### Interrupt Enable 2 (0x03)

### SHA\_DONE\_EN

| VALUE | ENUMERATION | DECODE                      |
|-------|-------------|-----------------------------|
| 0x0   |             | SHA_DONE interrupt disabled |
| 0x1   |             | SHA_DONE interrupt enabled  |

#### **Enable SHA\_DONE interrupt**

| BIT         | 7 | 6         | 5                | 4 | 3 | 2 | 1 | 0 |  |
|-------------|---|-----------|------------------|---|---|---|---|---|--|
| Field       | _ |           | FIFO_WR_PTR[6:0] |   |   |   |   |   |  |
| Reset       | - |           | 0x0              |   |   |   |   |   |  |
| Access Type | - | Read Only |                  |   |   |   |   |   |  |

#### FIFO Write Pointer (0x04)

FIFO WR PTR

This points to the location where the next sample will be written. This pointer advances for each sample pushed on to the circular FIFO.

Refer to FIFO Configuration for details.

#### FIFO\_RD\_PTR

| BIT         | 7 | 6 | 5                | 4 | 3 | 2 | 1 | 0 |
|-------------|---|---|------------------|---|---|---|---|---|
| Field       | _ |   | FIFO_RD_PTR[6:0] |   |   |   |   |   |
| Reset       | _ |   | 0x0              |   |   |   |   |   |
| Access Type | _ |   | Write, Read      |   |   |   |   |   |

#### FIFO Read Pointer (0x05)

The FIFO Read Pointer points to the location from where the processor gets the next sample from the FIFO via the serial interface. This advances each time a sample is popped from the circular FIFO.

The processor may also write to this pointer after reading the samples. This allows rereading (or retrying) samples from the FIFO. However writing to FIFO\_RD\_PTR may have adverse effects if it results in the FIFO being almost full.

Refer to FIFO Configuration for details.

| BIT         | 7 | 6 | 5                | 4 | 3 | 2 | 1 | 0 |  |
|-------------|---|---|------------------|---|---|---|---|---|--|
| Field       | - |   | OVF_COUNTER[6:0] |   |   |   |   |   |  |
| Reset       | - |   | 0x0              |   |   |   |   |   |  |
| Access Type | _ |   | Read Only        |   |   |   |   |   |  |

#### Over Flow Counter (0x06)

#### OVF\_COUNTER

Then FIFO is full any new samples will result in new or old samples getting lost depending on FIFO\_RO. OVF\_COUNTER counts the number of samples lost. It saturates at 0x7F.

Refer to FIFO Configuration for details.

| BIT         | 7 | 6                    | 5 | 4 | 3 | 2 | 1 | 0 |  |
|-------------|---|----------------------|---|---|---|---|---|---|--|
| Field       |   | FIFO_DATA_COUNT[7:0] |   |   |   |   |   |   |  |
| Reset       |   | 0x0                  |   |   |   |   |   |   |  |
| Access Type |   | Read Only            |   |   |   |   |   |   |  |

#### FIFO Data Counter (0x07)

#### FIFO\_DATA\_COUNT

This is a read-only register which holds the number of items available in the FIFO for the host to read. This increments when a new item is pushed to the FIFO, and decrements when the host reads an item from the FIFO.

#### MAX86140

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor for Wearable Health

Refer to FIFO Configuration for details.

| BIT         | 7 | 6              | 5 | 4 | 3 | 2 | 1 | 0 |  |
|-------------|---|----------------|---|---|---|---|---|---|--|
| Field       |   | FIFO_DATA[7:0] |   |   |   |   |   |   |  |
| Reset       |   | 0x0            |   |   |   |   |   |   |  |
| Access Type |   | Read Only      |   |   |   |   |   |   |  |

#### FIFO Data Register (0x08)

#### FIFO\_DATA

This is a read-only register and is used to get data from the FIFO. Refer to FIFO Configuration for details.

#### FIFO Configuration 1 (0x09)

| BIT         | 7 | 6 | 5                | 4 | 3 | 2 | 1 | 0 |  |
|-------------|---|---|------------------|---|---|---|---|---|--|
| Field       | - |   | FIFO_A_FULL[6:0] |   |   |   |   |   |  |
| Reset       | - |   | 0x3F             |   |   |   |   |   |  |
| Access Type | _ |   | Write, Read      |   |   |   |   |   |  |

#### FIFO\_A\_FULL

These bits indicate how many new samples can be written to the FIFO before the interrupt is asserted. For example, if set to 0xF, the interrupt triggers when there is 15 empty space left (113 entries), and so on.

Refer to FIFO Configuration for details.

| FIFO_A_FULL<6:0> | FREE SPACE BEFORE INTERRUPT | # OF SAMPLES IN FIFO |
|------------------|-----------------------------|----------------------|
| 0                | 0                           | 128                  |
| 1                | 1                           | 127                  |
| 2                | 2                           | 126                  |
| 3                | 3                           | 125                  |
|                  |                             |                      |
| 126              | 126                         | 2                    |
| 127              | 127                         | 1                    |

#### FIFO Configuration 2 (0x0A)

| BIT         | 7 | 6 | 5 | 4              | 3                 | 2               | 1           | 0 |
|-------------|---|---|---|----------------|-------------------|-----------------|-------------|---|
| Field       | ı | ı | - | FLUSH_<br>FIFO | FIFO_<br>STAT_CLR | A_FULL_<br>TYPE | FIFO_RO     | _ |
| Reset       | _ | _ | _ | 0x0            | 0x0               | 0x0             | 0x0         | _ |
| Access Type | _ | _ | _ | Write, Read    | Write, Read       | Write, Read     | Write, Read | _ |

#### **FLUSH FIFO**

When this bit is set to '1', the FIFO gets flushed, FIFO\_WR\_PTR and FIFO\_RD\_PTR are reset to zero and FIFO\_DATA\_COUNT becomes 0. The contents of the FIFO are lost.

FIFO\_FLUSH is a self-clearing bit.

Refer to FIFO Configuration for details.

#### FIFO\_STAT\_CLR

This defines whether the A-FULL interrupt should get cleared by FIFO\_DATA register read.

Refer to FIFO Configuration for details.

| VALUE | ENUMERATION DECODE |                                                                                                                         |  |  |
|-------|--------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|
| 0     | RD_DATA_NOCLR      | A_FULL and DATA_RDY interrupts do not get cleared by FIFO_DATA register read. They get cleared by status register read. |  |  |
| 1     | RD_DATA_CLR        | A_FULL and DATA_RDY interrupts get cleared by FIFO_DATA register read or status register read.                          |  |  |

#### A\_FULL\_TYPE

This defines the behavior of the A\_FULL interrupt.

| VALUE | ENUMERATION | DECODE                                                                                                                                                                                                           |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | AFULL_RPT   | A_FULL interrupt gets asserted when the a_full condition is detected. It is cleared by status register read, but re-asserts for every sample if the a_full condition persists.                                   |
| 1     | AFULL_ONCE  | A_FULL interrupt gets asserted only when the a_full condition is detected. The interrupt gets cleared on status register read, and does not re-assert for every sample until a new a-full condition is detected. |

#### FIFO\_RO

Push enable when FIFO is full:

This bit controls the behavior of the FIFO when the FIFO becomes completely filled with data.

Push to FIFO is enabled when FIFO is full if FIFO\_RO = 1 and old samples are lost. Both FIFO\_WR\_PTR increments for each sample after the FIFO is full. FIFO\_RD\_PTR also increments for each sample pushed to the FIFO.

Push to FIFO is disabled when FIFO is full if FIFO\_RO = 0 and new samples are lost. FIFO\_WR\_PTR does not increment for each sample after the FIFO is full.

When the device is in PROX mode, push to FIFO is enabled independent of FIFO\_RO setting.

Refer to FIFO Configuration for details.

| VALUE | ENUMERATION | DECODE                                     |  |  |  |
|-------|-------------|--------------------------------------------|--|--|--|
| 0     | OFF         | The FIFO stops on full.                    |  |  |  |
| 1     | ON          | The FIFO automatically rolls over on full. |  |  |  |

#### System Control (0x0D)

| BIT         | 7 | 6 | 5 | 4 | 3 | 2           | 1           | 0           |
|-------------|---|---|---|---|---|-------------|-------------|-------------|
| Field       | _ | _ | _ | _ | _ | LP_MODE     | SHDN        | RESET       |
| Reset       | _ | _ | _ | _ | _ | 0x0         | 0x0         | 0x0         |
| Access Type | _ | _ | _ | _ | _ | Write, Read | Write, Read | Write, Read |

#### LP\_MODE

In low power mode, the sensor can be dynamically powered down between samples to conserve power. This dynamic power down mode option only supports samples rates of 256sps and below.

| VALUE | ENUMERATION | DECODE                                                                                                                                                                                 |  |  |  |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0     | OFF         | Dynamic power down is disabled.                                                                                                                                                        |  |  |  |
| 1     | ON          | Dynamic power down is enabled. The device automatically enters low power mode between samples for samples rates 256sps and below.  This mode is not available for higher sample rates. |  |  |  |

#### **SHDN**

The part can be put into a power-save mode by setting this bit to one. While in power-save mode, all configuration registers retain their values, and write/read operations function as normal. All interrupts are cleared to zero in this mode.

| VALUE | ENUMERATION | DECODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | OFF         | The part is in normal operation. No action taken.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1     | ON          | The part can be put into a power-save mode by writing a '1' to this bit. While in this mode all configuration registers remain accessible and retain their data. ADC conversion data contained in the registers are previous values. Writeable registers also remain accessible in shutdown. All interrupts are cleared. In this mode the oscillator is shutdown and the part draws minimum current. If this bit is asserted during an active conversion then the conversion is aborted. |

#### **RESET**

When this bit is set, the part under-goes a forced power-on-reset sequence. All configuration, threshold and data registers including distributed registers are reset to their power-on-state. This bit then automatically becomes '0' after the reset sequence is completed.

#### PPG Sync Control (0x10)

| VALUE | ENUMERATION | DECODE                                                                                                                                                                                                                                                  |  |  |  |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0     | OFF         | The part is in normal operation. No action taken.                                                                                                                                                                                                       |  |  |  |
| 1     | ON          | The part under-goes a forced power-on-reset sequence. All configuration, threshold and data registers including distributed registers are reset to their power-on-state. This bit then automatically becomes '0' after the reset sequence is completed. |  |  |  |

#### TIME\_STAMP\_EN

| BIT         | 7                 | 6 | 5 | 4                     | 3 | 2      | 1        | 0 |
|-------------|-------------------|---|---|-----------------------|---|--------|----------|---|
| Field       | TIME_<br>STAMP_EN | - | _ | SW_<br>FORCE_<br>SYNC |   | GPIO_C | TRL[3:0] |   |
| Reset       | 0x0               | - | _ | 0x0                   |   | 0:     | k0       |   |
| Access Type | Write, Read       | - | _ | Write, Read           |   | Write, | Read     |   |

Enable pushing TIME\_STAMP to FIFO. Refer to FIFO Configuration for details.

#### SW\_FORCE\_SYNC

| VALUE | ENUMERATION | DECODE                                                     |  |  |  |
|-------|-------------|------------------------------------------------------------|--|--|--|
| 0x0   | DISABLE     | TIME_STAMP is not pushed to FIFO                           |  |  |  |
| 0x1   | ENABLE      | TIME_STAMP is pushed to FIFO for a block of eight samples. |  |  |  |

Writing a 1 to this bit, aborts current sample and starts a new sample. This is a self clearing bit.

#### GPIO\_CTRL

The table below shows how the two GPIO ports are control for different modes of operation.

When two devices are configured to work as Master-Slave device pairs, they have to be configured identical for the following configuration register fields:

- PPG\_SR
- PPG\_TINT
- SMP AVE
- TIME\_STAMP\_EN
- FIFO A FULL
- FIFO ROLLS ON FULL

Number of LED Sequence Registers (LEDC1 to LEDC6) programmed should be same in both the devices. In Exposure Trigger mode, if Ambient is programmed in one of the registers, it needs to be in the same LEDCx register in both the devices.

GPIO CTRL register for both the devices should be programmed to be either Sample Trigger or Exposure Trigger.

It is also important to configure the Slave first and then the Master.

DATA\_RDY or A\_FULL interrupt should be enabled only on the Master. When interrupt is asserted read the Master first and then the Slave. Read same number of items from both devices.

Refer to GPIO Configuration for details.

#### **PPG Configuration 1 (0x11)**

| GPIO_CTRL<br>[3:0] | GPIO1<br>FUNCTION          | GPIO2 FUNC-<br>TION                           | COMMENT                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------|----------------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000               | Tristate or<br>Mux Control | Disabled                                      | GPIO1 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO1 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO1 will be tristate. GPIO2 is disabled. Sample and exposure timing is controlled by the internal 32768Hz oscillator. |
| 0001               | Tristate or<br>Mux Control | Input<br>32768Hz or<br>32000Hz Clock<br>Input | GPIO1 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO1 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO1 will be tristate. GPIO2 is an input 32768/32000Hz. Sample and exposure timing is controlled by GPIO2 clock input. |

| GPIO_CTRL<br>[3:0] | GPIO1<br>FUNCTION                            | GPIO2 FUNC-<br>TION                           | COMMENT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|----------------------------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0010               | Input<br>Sample Trigger                      | Tristate or<br>Mux Control                    | GPIO1 is defined as a sample trigger input (Slave). This input can come from an external source or from another MAX86140 in master sample mode. GPIO2 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO2 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO2 will be tristate. Exposure timing is controlled by internal oscillator.                                                                                   |
| 0011               | Input<br>Sample Trigger                      | Input<br>32768Hz or<br>32000Hz Clock<br>Input | GPIO1 is defined as a sample trigger input (Slave). This input can come from an external source or from another MAX86140 in master sample mode. GPIO2 is an input 32768/32000Hz clock input. Exposure timing is controlled by GPIO2 clock input.                                                                                                                                                                                                                                                                                                                                                 |
| 0100               | Active Output<br>Master Sample<br>Output     | Tristate or<br>Mux Control                    | GPIO1 is defined as a master sample output. The GPIO1 output can be used to trigger a second sensor. When used with a second MAX86140 set to slave sample mode, the master sample timing will drive slave sample time. GPIO2 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO2 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO2 will be tristate. Sample and exposure timing is controlled by internal oscillator. |
| 0101               | Active Output<br>Master Sample<br>Output     | Input<br>32768/32000Hz<br>Clock Input         | GPIO1 is defined as a master sample output. The GPIO1 output can be used to trigger and second senor. When used with a second MAX86140 set to slave sample mode, the master sample timing will drive slave sample time. GPIO2 is an input 32768/32000Hz. Exposure timing is controlled by GPIO2 clock input.                                                                                                                                                                                                                                                                                     |
| 0110               | Input<br>Exposure Trig-<br>ger               | Tristate or<br>Mux Control                    | GPIO1 is defined as an exposure trigger input (Slave). This input can come from an external source or from another MAX86140 in master sample mode. Both sample and exposure timing is controlled by the GPIO1 input. GPIO2 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO2 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO2 will be tristate.                                                                    |
| 0111               | Active Output<br>Master Expo-<br>sure Output | Tristate or<br>Mux Control                    | GPIO1 is defined as a master sample output. The GPIO1 output can be used to trigger and second sensor. When used with a second MAX86140 set to slave exposure mode, the master exposure timing will drive slave exposure time. GPIO2 will be active if any of the LEDCn[3:0] states A, B, or C are enabled in the exposure sequence. In this case, GPIO2 will be high during exposures on LED4, LED5 or LED6, otherwise it will be low. If LEDCn[3:0] state A, B, or C is not enabled in the exposure sequence, GPIO2 will be tristate. Sample and exposure time is controlled internally        |
| 1000               | Active Output<br>Master Expo-<br>sure Output | Input<br>32768/32000Hz<br>Clock Input         | GPIO1 is defined as a master sample output. The GPIO1 output can be used to trigger and second sensor. When used with a second MAX86140 set to slave exposure mode, the master exposure timing will drive slave exposure time. GPIO2 is an input 32768/32000Hz. Sample and exposure timing is controlled by GPIO2 clock input.                                                                                                                                                                                                                                                                   |
| 1001               | Input<br>HW_FORCE_<br>SYNC                   | Input<br>32768Hz<br>or 32000Hz<br>Clock Input | GPIO1 is defined as a start of sample sync input. The rising edge of GPIO1 causes the present sample sequence to be terminated and reinitiated on the next rising edge of GPIO2 input. GPIO2 is an input 32768/32000Hz. Sample and exposure timing is controlled by GPIO2 clock input.                                                                                                                                                                                                                                                                                                           |

#### ALC\_DISABLE

| BIT         | 7                | 6               | 5 | 4 | 3                               | 2    | 1        | 0    |
|-------------|------------------|-----------------|---|---|---------------------------------|------|----------|------|
| Field       | ALC_DIS-<br>ABLE | ADD_OFF-<br>SET | - | _ | PPG1_ADC_RGE[1:0] PPG_TINT[1:0] |      | INT[1:0] |      |
| Reset       | 0x0              | 0               | _ | - | 0x0 0x3                         |      | κ3       |      |
| Access Type | Write, Read      | Write, Read     | _ | _ | Write,                          | Read | Write,   | Read |

#### ADD\_OFFSET

| VALUE | ENUMERATION | DECODE          |
|-------|-------------|-----------------|
| 0     | OFF         | ALC is enabled  |
| 1     | ON          | ALC is disabled |

ADD\_OFFSET is an option designed for dark current measurement. By adding offset to the PPG Data would allow dark current measurement without clipping the signal below 0.

When ADD\_OFFSET is set to 1, an offset is added to the PPG Data to be able to measure the dark current. The offset is 8192 counts if PPG\_SR is programmed for single pulse mode. The offset is 4096 counts if PPG\_SR is programmed for dual pulse mode.

#### PPG1\_ADC\_RGE

These bits set the ADC range of the SPO2 sensor as shown in the table below.

#### PPG\_TINT

| PPG_ADC_RGE<1:0> | LSB [PA] | FULL SCALE [NA] |
|------------------|----------|-----------------|
| 00               | 7,8125   | 4096            |
| 01               | 15.625   | 8192            |
| 10               | 31.25    | 16384           |
| 11               | 62.5     | 32768           |

These bits set the pulse width of the LED drivers and the integration time of PPG ADC as shown in the table below.

 $t_{PW} = t_{TINT} + t_{LED} SETLNG + 0.5\mu s$ 

#### PPG Configuration 2 (0x12)

|    | PPG_TINT<1:0> | TPW, PULSE WIDTH [MS] | TTINT, INTEGRATION TIME [MS] | RESOLUTION<br>BITS |
|----|---------------|-----------------------|------------------------------|--------------------|
| 00 |               | 21.3                  | 14.8                         | 19                 |
| 01 |               | 35.9                  | 29.4                         | 19                 |
| 10 |               | 65.2                  | 58.7                         | 19                 |
| 11 |               | 123.8                 | 117.3                        | 19                 |

#### PPG\_SR

| BIT         | 7 | 6 | 5           | 4            | 3   | 2           | 1 | 0 |
|-------------|---|---|-------------|--------------|-----|-------------|---|---|
| Field       |   |   | PPG_SR[4:0] | SMP_AVE[2:0] |     |             |   |   |
| Reset       |   |   | 0x11        |              | 0x0 |             |   |   |
| Access Type |   |   | Write, Read |              |     | Write, Read |   |   |

These bits set the effective sampling rate of the PPG sensor as shown in the table below. The default on-chip sampling clock frequency is 32768Hz.

Note: If a sample rate is set that can not be supported by the selected pulse width and number of exposures per sample, then the highest available sample rate will be automatically set. The user can read back this register to confirm the sample rate.

Maximum Sample rates (sps) supported for all the Integration Time (PPG\_TINT) and Number of Exposures:

| SAMPLING CLOCK<br>FREQUENCY | 32768HZ            | 32000HZ            |                      |
|-----------------------------|--------------------|--------------------|----------------------|
| PPG_SR<4:0>                 | Samples per Second | Samples per Second | Pulses Per Sample, N |
| 0x00                        | 24.995             | 24.409             | 1                    |
| 0x01                        | 50.027             | 48.855             | 1                    |
| 0x02                        | 84.021             | 82.051             | 1                    |
| 0x03                        | 99.902             | 97.561             | 1                    |
| 0x04                        | 199,805            | 195.122            | 1                    |
| 0x05                        | 399.610            | 390.244            | 1                    |
| 0x06                        | 24.995             | 24.409             | 2                    |
| 0x07                        | 50.027             | 48.855             | 2                    |
| 0x08                        | 84.021             | 82.051             | 2                    |
| 0x09                        | 99.902             | 97.561             | 2                    |
| 0x0A                        | 8.000              | 7.8125             | 1                    |
| 0x0B                        | 16.000             | 15.625             | 1                    |
| 0x0C                        | 32.000             | 31.250             | 1                    |
| 0x0D                        | 64.000             | 62.500             | 1                    |
| 0x0E                        | 128.000            | 125.000            | 1                    |
| 0x0F                        | 256.000            | 250.000            | 1                    |
| 0x10                        | 512.000            | 500.000            | 1                    |
| 0x11                        | 1024.000           | 1000.000           | 1                    |
| 0x12                        | 2048.000           | 2000.000           | 1                    |
| 0x13                        | 4096.000           | 4000.000           | 1                    |
| 0x14-1F                     | Reserved           | Reserved           | Reserved             |

SMP\_AVE

| NUMBER OF EXPO-<br>SURE PER SAMPLE | PPG_TINT = 0<br>(14.8MS) | PPG_TINT = 1<br>(29.4MS) | PPG_TINT = 2<br>(58.7MS) | PPG_TINT = 3<br>(117.3MS) |
|------------------------------------|--------------------------|--------------------------|--------------------------|---------------------------|
| 1 Exposure, N=1                    | 4096                     | 2048                     | 2048                     | 1024                      |
| 2 Exposures, N=1                   | 2048                     | 1024                     | 1024                     | 512                       |
| 3 Exposures, N=1                   | 1024                     | 1024                     | 512                      | 512                       |
| 4 Exposures, N=1                   | 1024                     | 512                      | 512                      | 400                       |
| 5 Exposures, N=1                   | 512                      | 512                      | 512                      | 256                       |
| 6 Exposures, N=1                   | 512                      | 512                      | 400                      | 256                       |
| 1 Exposure, N=2                    | 100                      | 100                      | 100                      | 100                       |
| 2 Exposures, N=2                   | 100                      | 84                       | 84                       | 84                        |
| 3 Exposures, N=2                   | 50                       | 50                       | 50                       | 50                        |
| 4 Exposures, N=2                   | 25                       | 25                       | 25                       | 25                        |
| 5 Exposures, N=2                   | 25                       | 25                       | 25                       | 25                        |
| 6 Exposures, N=2                   | 25                       | 25                       | 25                       | 25                        |

To reduce the amount of data throughput, adjacent samples (in each individual channel) can be averaged and decimated on the chip by setting this register.

These bits set the number of samples that are averaged on chip before being written to the FIFO.

| SMP_AVE[2:0] | SAMPLE AVERAGE   |
|--------------|------------------|
| 000          | 1 (no averaging) |
| 001          | 2                |
| 010          | 4                |
| 011          | 8                |
| 100          | 16               |
| 101          | 32               |
| 110          | 64               |
| 111          | 128              |

When BURST\_EN is 1, SMP\_AVE defines the number of conversions per burst. Depending on the BURST\_RATE programmed and the PPG\_SR used, it may not be possible to accommodate some of SMP\_AVE values. In that case, SMP\_AVE will take the highest value that can be accommodated. If SMP\_AVE = 0 cannot be accommodated, burst mode is disabled.

**Note:** PPG\_SR itself depends on Number of conversions per sample (LEDC1 to LEDC6) and the LED Integration time (PPG\_TINT).

The following table shows the maximum SMP\_AVE allowed for various configurations of BURST\_RATE and PPG\_SR:

#### PPG Configuration 3 (0x13)

| PPG_SR USED         | BURST_RATE =<br>0 (8 HZ) | BURST_RATE =<br>1 (32 HZ) | BURST_RATE =<br>2 (84 HZ) | BURST_RATE = 3 (256 HZ) |
|---------------------|--------------------------|---------------------------|---------------------------|-------------------------|
| 0 (25 Hz, N = 1)    | 1                        | DIS                       | DIS                       | DIS                     |
| 1 (50 Hz, N = 1)    | 2                        | 0                         | DIS                       | DIS                     |
| 2 (84 Hz, N = 1)    | 3                        | 1                         | DIS                       | DIS                     |
| 3 (100 Hz, N = 1)   | 3                        | 1                         | DIS                       | DIS                     |
| 4 (200 Hz, N = 1)   | 4                        | 2                         | 0                         | DIS                     |
| 5 (400 Hz, N = 1)   | 5                        | 3                         | 1                         | DIS                     |
| 6 (25 Hz, N = 2)    | 1                        | DIS                       | DIS                       | DIS                     |
| 7 (50 Hz, N = 2)    | 2                        | 0                         | DIS                       | DIS                     |
| 8 (84 Hz, N = 2)    | 3                        | 1                         | DIS                       | DIS                     |
| 9 (100 Hz, N = 2)   | 3                        | 1                         | DIS                       | DIS                     |
| A (8 Hz, N = 1)     | DIS                      | DIS                       | DIS                       | DIS                     |
| B (16 Hz, N = 1)    | 0                        | DIS                       | DIS                       | DIS                     |
| C (32 Hz, N = 1)    | 1                        | DIS                       | DIS                       | DIS                     |
| D (64 Hz, N = 1)    | 2                        | 0                         | DIS                       | DIS                     |
| E (128 Hz, N = 1)   | 3                        | 1                         | 0                         | DIS                     |
| F (256 Hz, N = 1)   | 4                        | 2                         | 1                         | DIS                     |
| 10 (512 Hz, N = 1)  | 5                        | 3                         | 2                         | DIS                     |
| 11 (1024 Hz, N = 1) | 6                        | 4                         | 3                         | 0                       |
| 12 (2048 Hz, N = 1) | 7                        | 5                         | 4                         | 1                       |
| 13 (4096 Hz, N = 1) | 7                        | 6                         | 5                         | 2                       |

#### LED\_SETLNG

| BIT         | 7                       | 6 | 5                | 4 | 3 | 2               | 1    | 0           |
|-------------|-------------------------|---|------------------|---|---|-----------------|------|-------------|
| Field       | LED_SETLNG[1:0]         |   | DIG_FILT_<br>SEL | _ | _ | BURST_RATE[1:0] |      | BURST_EN    |
| Reset       | 0x1                     |   | 0x0              | _ | _ | 0>              | (0   | 0x0         |
| Access Type | Access Type Write, Read |   | Write, Read      | _ | - | Write,          | Read | Write, Read |

Delay from rising edge of LED to start of ADC integration. This allows for the LED current to settle before the start of ADC integration.

#### DIG\_FILT\_SEL

| TLED_SETLNG, LED_SETLNG<1:0> | DELAY (MS)    |
|------------------------------|---------------|
| 00                           | 4.0           |
| 01                           | 6.0 (default) |
| 10                           | 8.0           |
| 11                           | 12.0          |

Select Digital Filter Type

#### BURST\_RATE

| VALUE | ENUMERATION | DECODE  |
|-------|-------------|---------|
| 0x0   |             | Use CDM |
| 0x1   |             | Use FDM |

#### **BURST\_EN**

| VALUE | ENUMERATION | DECODE |
|-------|-------------|--------|
| 0x0   |             | 8 Hz   |
| 0x1   |             | 32 Hz  |
| 0x2   |             | 84 Hz  |
| 0x3   |             | 256 Hz |

When Burst Mode is disabled, PPG data conversions are continuous at the sample rate defined by PPG\_SR register,

When Burst mode is enabled, a burst of PPG data conversions occur at the sample rate defined by PPG\_SR register. Number of conversion in the burst is defined by the SMP\_AVE register. Average data from the burst of data conversions is pushed to the FIFO. The burst repeats at the rate defined in BURST\_RATE[2:0] register. If the number of conversions cannot be accommodated, the device will use the next highest number of conversions.

If the effective PPG\_SR is too slow to accommodate the burst rate programmed, BURST\_EN is automatically set to 0, and the device runs in continuous mode.

Note Each data conversion cycle is a sequence of conversions defined in the LEDC1 to LEDC6 registers.

#### PROX\_INT\_THRESH

| VALUE | ENUMERATION | DECODE                        |  |  |  |
|-------|-------------|-------------------------------|--|--|--|
| 0x0   |             | Disable Burst Conversion mode |  |  |  |
| 0x1   |             | Enable Burst Conversion Mode  |  |  |  |

#### **Prox Interrupt Threshold (0x14)**

| BIT         | 7               | 6                    | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|-------------|-----------------|----------------------|---|---|---|---|---|---|--|--|
| Field       |                 | PROX_INT_THRESH[7:0] |   |   |   |   |   |   |  |  |
| Reset       | 0x00            |                      |   |   |   |   |   |   |  |  |
| Access Type | ype Write, Read |                      |   |   |   |   |   |   |  |  |

This register sets the LED1 ADC count that will trigger the transition between proximity mode and normal mode. The threshold is defined as the 8 MSB bits of the ADC count. For example, if PROX\_INT\_THRESH[7:0] = 0x01, then an ADC value of 2048 (decimal) or higher triggers the PROX interrupt. If PROX\_INT\_THRESH[7:0] = 0xFF, then only a saturated ADC triggers the interrupt.

Please see the Proximity Function section in the detailed description for more details on the operation of proximity mode. PDBIAS1

#### Photo Diode Bias (0x15)

| BIT         | 7 | 6 | 5 | 4 | 3 | 2            | 1 | 0 |
|-------------|---|---|---|---|---|--------------|---|---|
| Field       | _ | _ | _ | _ | _ | PDBIAS1[2:0] |   |   |
| Reset       | _ | _ | _ | _ | _ | 0x0          |   |   |
| Access Type | - | _ | _ | - | - | Write, Read  |   |   |

See *Photo Diode Biasing* for more information.

#### Picket Fence (0x16)

| PDBIAS1<2:0>     | PHOTO DIODE CAPACITANCE |
|------------------|-------------------------|
| 0x001            | 0pF to 65pF             |
| 0x101            | 65pF to 130pF           |
| 0x110            | 130pF to 260pF          |
| 0x111            | 260pF to 520pF          |
| All other values | Not recommended         |

#### **PF\_ENABLE**

| BIT         | 7              | 6           | 5           | 4 | 3                   | 2 | 1                             | 0 |
|-------------|----------------|-------------|-------------|---|---------------------|---|-------------------------------|---|
| Field       | PF_EN-<br>ABLE | PF_ORDER    | IIR_TC[1:0] |   | IIR_INIT_VALUE[1:0] |   | THRESHOLD_SIGMA_<br>MULT[1:0] |   |
| Reset       | 0x0            | 0x1         | 0x00        |   | 0x00                |   | 0x00                          |   |
| Access Type | Write, Read    | Write, Read | Write, Read |   | Write, Read         |   | Write, Read                   |   |

Refer to Picket Fence Detect-and-Replace Function for details.

PF\_ENABLE set to 1 enabled the picket-fence detect and replace method.

#### PF\_ORDER

| VALUE | ENUMERATION | DECODE                    |  |  |  |  |
|-------|-------------|---------------------------|--|--|--|--|
| 0     | OFF         | Disable (default)         |  |  |  |  |
| 1     | ON          | Enable Detect and Replace |  |  |  |  |

PF\_ORDER determines which prediction method is used: the last sample or a linear fit to the previous four samples. Refer to *Picket Fence Detect-and-Replace Function* for details.

#### IIR\_TC

| VALUE | ENUMERATION | DECODE                                          |
|-------|-------------|-------------------------------------------------|
| 0     | OFF         | Last Sample (1 point)                           |
| 1     | ON          | Fit 4 points to a line for prediction (default) |

IIR\_TC<1:0> determines the IIR filter bandwidth where the lowest setting has the narrowest bandwidth of a first-order filter.

Refer to Picket Fence Detect-and-Replace Function for details.

#### IIR\_INIT\_VALUE

| IIR_TC<1:0> | COEFFICIENT | SAMPLES TO 90% |
|-------------|-------------|----------------|
| 00          | 1/64        | 146            |
| 01          | 1/32        | 72             |
| 10          | 1/16        | 35             |
| 11          | 1/8         | 17             |

This IIR filter estimates the true standard deviation between the actual and predicted sample and tracks the ADC Range setting.

Refer to Picket Fence Detect-and-Replace Function for details.

#### THRESHOLD\_SIGMA\_MULT

| IIR_INIT_VALUE<1:0> | CODE |
|---------------------|------|
| 00                  | 64   |
| 01                  | 48   |
| 10                  | 32   |
| 11                  | 24   |

GAIN resulting from the SIGMA\_MULT<1:0> setting determines the number of standard deviations of the delta between the actual and predicted sample beyond which a picket-fence event is triggered.

Refer to Picket Fence Detect-and-Replace Function for details.

#### LED Sequence Register 1 (0x20)

| THRESHOLD_SIGMA_MULT<1:0> | GAIN |
|---------------------------|------|
| 00                        | 4    |
| 01                        | 8    |
| 10                        | 16   |
| 11                        | 32   |

#### LEDC2

| BIT         | 7 | 6      | 5      | 4 | 3           | 2 | 1 | 0 |  |
|-------------|---|--------|--------|---|-------------|---|---|---|--|
| Field       |   | LEDC   | 2[3:0] |   | LEDC1[3:0]  |   |   |   |  |
| Reset       |   | 0>     | (0     |   | 0x0         |   |   |   |  |
| Access Type |   | Write, | Read   |   | Write, Read |   |   |   |  |

These bits set the data type for LED Sequence 2 of the FIFO.

See *FIFO Configuration* for more information.

#### LEDC1

These bits set the data type for LED Sequence 1 of the FIFO.

See FIFO Configuration for more information.

#### LED Sequence Register 2 (0x21)

#### LEDC4

| BIT         | 7          | 6           | 5 | 4 | 3          | 2           | 1 | 0 |  |
|-------------|------------|-------------|---|---|------------|-------------|---|---|--|
| Field       | LEDC4[3:0] |             |   |   | LEDC3[3:0] |             |   |   |  |
| Reset       | 0x0        |             |   |   | 0x0        |             |   |   |  |
| Access Type |            | Write, Read |   |   |            | Write, Read |   |   |  |

These bits set the data type for LED Sequence 4 of the FIFO.

See FIFO Configuration for more information.

#### LEDC3

These bits set the data type for LED Sequence 3 of the FIFO.

See FIFO Configuration for more information.

#### LED Sequence Register 3 (0x22)

#### LEDC6

| BIT         | 7          | 6           | 5 | 4 | 3          | 2           | 1 | 0 |  |
|-------------|------------|-------------|---|---|------------|-------------|---|---|--|
| Field       | LEDC6[3:0] |             |   |   | LEDC5[3:0] |             |   |   |  |
| Reset       | 0x0        |             |   |   | 0x0        |             |   |   |  |
| Access Type |            | Write, Read |   |   |            | Write, Read |   |   |  |

These bits set the data type for LED Sequence 6 of the FIFO.

See FIFO Configuration for more information.

#### LEDC5

These bits set the data type for LED Sequence 5 of the FIFO.

See FIFO Configuration for more information.

#### LED1 PA (0x23)

#### LED1\_DRV

| BIT         | 7 | 6             | 5 | 4      | 3    | 2 | 1 | 0 |  |  |
|-------------|---|---------------|---|--------|------|---|---|---|--|--|
| Field       |   | LED1_DRV[7:0] |   |        |      |   |   |   |  |  |
| Reset       |   | 0x00          |   |        |      |   |   |   |  |  |
| Access Type |   |               |   | Write, | Read |   |   |   |  |  |

These bits set the nominal drive current of of LED 1 as shown in the table below.

#### LED2 PA (0x24)

| LEDX_RGE<1:0> | 00              | 01              | 10              | 11              |
|---------------|-----------------|-----------------|-----------------|-----------------|
| LEDx_PA<7:0>  | LED Current[mA] | LED Current[mA] | LED Current[mA] | LED Current[mA] |
| 00000000      | 0.00            | 0.00            | 0.00            | 0.00            |
| 0000001       | 0.12            | 0.24            | 0.36            | 0.48            |
| 0000010       | 0.24            | 0.48            | 0.73            | 0.97            |
| 00000011      | 0.36            | 0.73            | 1.09            | 1.45            |
|               |                 |                 |                 |                 |
| 11111100      | 30.6            | 61.3            | 91.9            | 122.5           |
| 11111101      | 30.8            | 61.5            | 92.3            | 123.0           |
| 11111110      | 30.9            | 61.8            | 92.6            | 123.5           |
| 11111111      | 31.0            | 62.0            | 93.0            | 124.0           |
| LSB           | 0.12            | 0.24            | 0.36            | 0.48            |

| BIT         | 7 | 6             | 5 | 4      | 3    | 2 | 1 | 0 |  |
|-------------|---|---------------|---|--------|------|---|---|---|--|
| Field       |   | LED2_DRV[7:0] |   |        |      |   |   |   |  |
| Reset       |   | 0x00          |   |        |      |   |   |   |  |
| Access Type |   |               |   | Write, | Read |   |   |   |  |

#### LED2\_DRV

These bits set the nominal drive current of of LED 2. See LED1\_DRV for description.

#### LED3\_PA (0x25)

| BIT         | 7 | 6             | 5 | 4      | 3    | 2 | 1 | 0 |  |
|-------------|---|---------------|---|--------|------|---|---|---|--|
| Field       |   | LED3_DRV[7:0] |   |        |      |   |   |   |  |
| Reset       |   | 0x00          |   |        |      |   |   |   |  |
| Access Type |   |               |   | Write, | Read |   |   |   |  |

#### LED3\_DRV

These bits set the nominal drive current of of LED 2. See LED1\_DRV for description.

#### LED4 PA (0x26)

| BIT         | 7 | 6             | 5 | 4      | 3    | 2 | 1 | 0 |  |
|-------------|---|---------------|---|--------|------|---|---|---|--|
| Field       |   | LED4_DRV[7:0] |   |        |      |   |   |   |  |
| Reset       |   | 0x00          |   |        |      |   |   |   |  |
| Access Type |   |               |   | Write, | Read |   |   |   |  |

#### LED4\_DRV

These bits set the nominal drive current of of LED 4. See LED1\_DRV for description.

#### LED5 PA (0x27)

| BIT         | 7 | 6             | 5 | 4      | 3    | 2 | 1 | 0 |  |  |
|-------------|---|---------------|---|--------|------|---|---|---|--|--|
| Field       |   | LED5_DRV[7:0] |   |        |      |   |   |   |  |  |
| Reset       |   | 0x00          |   |        |      |   |   |   |  |  |
| Access Type |   |               |   | Write, | Read |   |   |   |  |  |

#### LED5 DRV

These bits set the nominal drive current of of LED 5. See LED1\_DRV for description.

#### LED6 PA (0x28)

| BIT         | 7 | 6             | 5 | 4      | 3    | 2 | 1 | 0 |  |
|-------------|---|---------------|---|--------|------|---|---|---|--|
| Field       |   | LED6_DRV[7:0] |   |        |      |   |   |   |  |
| Reset       |   | 0x00          |   |        |      |   |   |   |  |
| Access Type |   |               |   | Write, | Read |   |   |   |  |

#### LED6\_DRV

These bits set the nominal drive current of of LED 6. See LED1\_DRV for description.

#### LED PILOT PA (0x29)

| BIT         | 7 | 6             | 5 | 4      | 3    | 2 | 1 | 0 |  |  |
|-------------|---|---------------|---|--------|------|---|---|---|--|--|
| Field       |   | PILOT_PA[7:0] |   |        |      |   |   |   |  |  |
| Reset       |   | 0x00          |   |        |      |   |   |   |  |  |
| Access Type |   |               |   | Write, | Read |   |   |   |  |  |

#### PILOT\_PA

The purpose of PILOT\_PA<7:0> is to set the LED power during the PROX mode, as well as in Multi-LED mode. These bits set the nominal drive current for the pilot mode as shown in the table below.

When LED x is used, the respective LEDx\_RGE<1:0> is used to control the range of the LED driver in conjunction with PILOT\_PA<7:0>. For instance, if LED1 is used in the PILOT mode, then, LED1\_RGE<1:0> together with PILOT\_PA<7:0> will be used to set the LED1 current.

| LEDX_RGE<1:0> | 00              | 01              | 10              | 11              |
|---------------|-----------------|-----------------|-----------------|-----------------|
| PILOT_PA<7:0> | LED Current[mA] | LED Current[mA] | LED Current[mA] | LED Current[mA] |
| 00000000      | 0.00            | 0.00            | 0.00            | 0.00            |
| 0000001       | 0.12            | 0.24            | 0.36            | 0.48            |
| 0000010       | 0.24            | 0.48            | 0.73            | 0.97            |
| 0000011       | 0.36            | 0.73            | 1.09            | 1.45            |
|               |                 |                 |                 |                 |
| 11111100      | 30.6            | 61.3            | 91.9            | 122.5           |
| 11111101      | 30.8            | 61.5            | 92.3            | 123.0           |
| 11111110      | 30.9            | 61.8            | 92.6            | 123.5           |
| 11111111      | 31.0            | 62.0            | 93.0            | 124.0           |
| LSB           | 0.12            | 0.24            | 0.36            | 0.48            |

#### LED Range 1 (0x2A)

| BIT         | 7 | 6 | 5             | 4    | 3             | 2 | 1             | 0 |
|-------------|---|---|---------------|------|---------------|---|---------------|---|
| Field       | _ | _ | LED3_RGE[1:0] |      | LED2_RGE[1:0] |   | LED1_RGE[1:0] |   |
| Reset       | _ | - | 0x00          |      | 0x00          |   | 0x00          |   |
| Access Type | _ | _ | Write,        | Read | Write, Read   |   | Write, Read   |   |

#### LED3\_RGE

Range selection of the LED current. Refer to LED1\_PA[7:0] for more details.

| LEDX_RGE<1:0><br>(X = 1 TO 6) | LED CURRENT[MA] |
|-------------------------------|-----------------|
| 00                            | 31              |
| 01                            | 62              |
| 10                            | 93              |
| 11                            | 124             |

#### LED2\_RGE

Range selection of the LED current. Refer to LED3\_RGE[1:0] for more details.

LED1\_RGE

Range selection of the LED current. Refer to LED3\_RGE[1:0] for more details.

#### LED Range 2 (0x2B)

| BIT         | 7 | 6 | 5             | 4    | 3             | 2 | 1             | 0  |
|-------------|---|---|---------------|------|---------------|---|---------------|----|
| Field       | _ | - | LED6_RGE[1:0] |      | LED5_RGE[1:0] |   | LED4_RGE[1:0] |    |
| Reset       | - | - | 0x00          |      | 0x00          |   | 0x            | 00 |
| Access Type | _ | _ | Write,        | Read | Write, Read   |   | Write, Read   |    |

#### LED6\_RGE

Range selection of the LED current. Refer to LED3\_RGE[1:0] for more details.

#### LED5\_RGE

Range selection of the LED current. Refer to LED3\_RGE[1:0] for more details.

#### LED4\_RGE

Range selection of the LED current. Refer to LED3\_RGE[1:0] for more details.

#### S1 HI RES DAC1 (0x2C)

| BIT         | 7                    | 6 | 5                 | 4 | 3      | 2    | 1 | 0 |
|-------------|----------------------|---|-------------------|---|--------|------|---|---|
| Field       | S1_HRES_<br>DAC1_OVR | _ | S1_HRES_DAC1[5:0] |   |        |      |   |   |
| Reset       | 0x0                  | - | 0x00              |   |        |      |   |   |
| Access Type | Write, Read          | _ |                   |   | Write, | Read |   |   |

#### S1\_HRES\_DAC1\_OVR

| VALUE | ENUMERATION | DECODE                                                                                            |
|-------|-------------|---------------------------------------------------------------------------------------------------|
| 0     | OFF         | The high resolution DAC for PPG1 is controlled by the chip.                                       |
| 1     | ON          | This allows the high resolution DAC for PPG1 used in exposure 1 to be controlled by the software. |

#### S1\_HRES\_DAC1

If S1\_ HI\_RES\_DAC1\_OVR = 1 then bits S1\_HRES\_DAC1<5:0> set the high-resolution DAC code used in PPG1 ADC. This allows the algorithm to control ADC subranging

If S1\_ HI\_RES\_DAC1\_OVR = 0 then bits S1\_HRES\_DAC1<5:0> have no effect on the PPG1 ADC

#### S2 HI RES DAC1 (0x2D)

| BIT         | 7                    | 6 | 5                 | 4    | 3      | 2    | 1 | 0 |  |  |
|-------------|----------------------|---|-------------------|------|--------|------|---|---|--|--|
| Field       | S2_HRES_<br>DAC1_OVR | _ | S2_HRES_DAC1[5:0] |      |        |      |   |   |  |  |
| Reset       | 0x0                  | - |                   | 0x00 |        |      |   |   |  |  |
| Access Type | Write, Read          | _ |                   |      | Write, | Read |   |   |  |  |

#### S2\_HRES\_DAC1\_OVR

| VALUE | ENUMERATION | DECODE                                                                                            |
|-------|-------------|---------------------------------------------------------------------------------------------------|
| 0     | OFF         | The high resolution DAC for PPG1 is controlled by the chip.                                       |
| 1     | ON          | This allows the high resolution DAC for PPG1 used in exposure 2 to be controlled by the software. |

#### S2\_HRES\_DAC1

If S2\_ HI\_RES\_DAC1\_OVR = 1 then bits S2\_HRES\_DAC1<5:0> set the high resolution DAC code used in PPG1 ADC. This allows the algorithm to control ADC subranging

If S2\_ HI\_RES\_DAC1\_OVR = 0 then bits S2\_HRES\_DAC1<5:0> have no effect on the PPG1 ADC

#### S3 HI RES DAC1 (0x2E)

| BIT         | 7                    | 6 | 5                 | 4   | 3      | 2    | 1 | 0 |  |
|-------------|----------------------|---|-------------------|-----|--------|------|---|---|--|
| Field       | S3_HRES_<br>DAC1_OVR | - | S3_HRES_DAC1[5:0] |     |        |      |   |   |  |
| Reset       | 0x0                  | _ |                   | 0x0 |        |      |   |   |  |
| Access Type | Write, Read          | _ |                   |     | Write, | Read |   |   |  |

#### S3\_HRES\_DAC1\_OVR

| VALUE | ENUMERATION | DECODE                                                                                           |
|-------|-------------|--------------------------------------------------------------------------------------------------|
| 0x0   | OFF         | The high resolution DAC for PPG1 is controlled by the chip                                       |
| 0x1   | ON          | This allows the high resolution DACfor PPG1 used in exposure 3 to be controlled by the software. |

#### S3\_HRES\_DAC1

If S3\_ HI\_RES\_DAC1\_OVR = 1 then bits S3\_HRES\_DAC1<5:0> set the high-resolution DAC code used in PPG1 ADC. This allows the algorithm to control ADC subranging

If S3\_ HI\_RES\_DAC1\_OVR = 0 then bits S3\_HRES\_DAC1<5:0> have no effect on the PPG1 ADC

#### S4 HI RES DAC1 (0x2F)

| BIT         | 7                    | 6 | 5                 | 4 | 3      | 2    | 1 | 0 |
|-------------|----------------------|---|-------------------|---|--------|------|---|---|
| Field       | S4_HRES_<br>DAC1_OVR | ı | S4_HRES_DAC1[5:0] |   |        |      |   |   |
| Reset       | 0b0                  | _ | 0x0               |   |        |      |   |   |
| Access Type | Write, Read          | _ |                   |   | Write, | Read |   |   |

#### S4\_HRES\_DAC1\_OVR

| VALUE | ENUMERATION | DECODE                                                                                            |
|-------|-------------|---------------------------------------------------------------------------------------------------|
| 0x0   | OFF         | The high resolution DAC for PPG1 is controlled by the chip.                                       |
| 0x1   | ON          | This allows the high resolution DAC for PPG1 used in exposure 4 to be controlled by the software. |

#### S4\_HRES\_DAC1

If S4\_ HI\_RES\_DAC1\_OVR = 1 then bits S4\_HRES\_DAC1<5:0> set the high-resolution DAC code used in PPG1 ADC. This allows the algorithm to control ADC subranging

If S4\_ HI\_RES\_DAC1\_OVR = 0 then bits S4\_HRES\_DAC1<5:0> have no effect on the PPG1 ADC

#### **S5 HI RES DAC1 (0x30)**

| BIT         | 7                    | 6 | 5                 | 4   | 3      | 2    | 1 | 0 |  |  |
|-------------|----------------------|---|-------------------|-----|--------|------|---|---|--|--|
| Field       | S5_HRES_<br>DAC1_OVR | _ | S5_HRES_DAC1[5:0] |     |        |      |   |   |  |  |
| Reset       | 0b0                  | _ |                   | 0x0 |        |      |   |   |  |  |
| Access Type | Write, Read          | _ |                   |     | Write, | Read |   |   |  |  |

#### S5\_HRES\_DAC1\_OVR

| VALUE | ENUMERATION | DECODE                                                                                            |
|-------|-------------|---------------------------------------------------------------------------------------------------|
| 0x0   | OFF         | The high resolution DAC for PPG1 is controlled by the chip.                                       |
| 0x1   | ON          | This allows the high resolution DAC for PPG1 used in exposure 5 to be controlled by the software. |

#### S5\_HRES\_DAC1

If S5\_ HI\_RES\_DAC1\_OVR = 1 then bits S5\_HRES\_DAC1<5:0> set the high-resolution DAC code used in PPG1 ADC. This allows the algorithm to control ADC subranging

If S5\_ HI\_RES\_DAC1\_OVR = 0 then bits S5\_HRES\_DAC1<5:0> have no effect on the PPG1 ADC

#### **S6 HI RES DAC1 (0x31)**

| BIT         | 7                    | 6 | 5                 | 4 | 3      | 2    | 1 | 0 |  |
|-------------|----------------------|---|-------------------|---|--------|------|---|---|--|
| Field       | S6_HRES_<br>DAC1_OVR | _ | S6_HRES_DAC1[5:0] |   |        |      |   |   |  |
| Reset       | 0b0                  | _ | 0x0               |   |        |      |   |   |  |
| Access Type | Write, Read          | _ |                   |   | Write, | Read |   |   |  |

#### S6\_HRES\_DAC1\_OVR

| VALUE | ENUMERATION | DECODE                                                                                            |
|-------|-------------|---------------------------------------------------------------------------------------------------|
| 0x0   | OFF         | The high resolution DAC for PPG1 is controlled by the chip.                                       |
| 0x1   | ON          | This allows the high resolution DAC for PPG1 used in exposure 6 to be controlled by the software. |

#### S6\_HRES\_DAC1

If S6\_ HI\_RES\_DAC1\_OVR = 1 then bits S6\_HRES\_DAC1<5:0> set the high-resolution DAC code used in PPG1 ADC. This allows the algorithm to control ADC subranging

If S6\_ HI\_RES\_DAC1\_OVR = 0 then bits S6\_HRES\_DAC1<5:0> have no effect on the PPG1 ADC

#### **Die Temperature Configuration (0x40)**

| BIT         | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |
|-------------|---|---|---|---|---|---|---|-------------|
| Field       | - | _ | _ | _ | _ | - | _ | TEMP_EN     |
| Reset       | - | - | - | - | - | - | - | 0x0         |
| Access Type | _ | _ | _ | _ | _ | _ | _ | Write, Read |

#### TEMP\_EN

The bit gets cleared after temperature measurement completes.

| VALUE | ENUMERATION | DECODE                            |
|-------|-------------|-----------------------------------|
| 0x0   |             | Idle                              |
| 0x1   |             | Start one temperature measurement |

#### Die Temperature Integer (0x41)

| BIT         | 7 | 6             | 5 | 4    | 3    | 2 | 1 | 0 |  |  |
|-------------|---|---------------|---|------|------|---|---|---|--|--|
| Field       |   | TEMP_INT[7:0] |   |      |      |   |   |   |  |  |
| Reset       |   | 0x0           |   |      |      |   |   |   |  |  |
| Access Type |   |               |   | Read | Only |   |   |   |  |  |

#### TEMP\_INT

This register stores the integer temperature data in 2s complimnet form.  $0x00 = 0^{\circ}C$ ,  $0xFF = 127^{\circ}C$  and  $0x80 = -128^{\circ}C$  **Note:** TINT and TFRAC registers should be read through the Serial Interface in burst mode, to ensure that they belong to the same sample.

Die Temperature Fraction (0x42)

| BIT         | 7 | 6 | 5 | 4 | 3              | 2    | 1    | 0 |  |
|-------------|---|---|---|---|----------------|------|------|---|--|
| Field       | _ | _ | _ | _ | TEMP_FRAC[3:0] |      |      |   |  |
| Reset       | _ | _ | _ | _ | 0x0            |      |      |   |  |
| Access Type | - | _ | _ | _ |                | Read | Only |   |  |

#### TEMP\_FRAC

This register store the fractional temperature data in increments of 0.0625°C. 0x1 = 0.0625°C and 0xF = 0.9375°C.

**Note:** TINT and TFRAC registers should be read through the Serial Interface in burst mode, to ensure that they belong to the same sample.

#### SHA Command (0xF0)

| BIT         | 7 | 6            | 5 | 4      | 3    | 2 | 1 | 0 |  |  |
|-------------|---|--------------|---|--------|------|---|---|---|--|--|
| Field       |   | SHA_CMD[7:0] |   |        |      |   |   |   |  |  |
| Reset       |   | 0x0          |   |        |      |   |   |   |  |  |
| Access Type |   |              |   | Write, | Read |   |   |   |  |  |

#### SHA\_CMD

| VALUE  | ENUMERATION | DECODE             |
|--------|-------------|--------------------|
| 0X35   |             | MAC WITH ROM ID    |
| 0X36   |             | MAC WITHOUT ROM ID |
| OTHERS |             | RESERVED           |

#### **SHA Configuration (0xF1)**

| BIT         | 7 | 6 | 5 | 4 | 3 | 2 | 1           | 0             |
|-------------|---|---|---|---|---|---|-------------|---------------|
| Field       | - | _ | - | _ | _ | _ | SHA_EN      | SHA_<br>START |
| Reset       | - | - | - | - | - | - | 0x0         | 0x0           |
| Access Type | _ | _ | _ | _ | _ | _ | Write, Read | Write, Read   |

#### SHA\_EN

Authentication is performed using a FIPS 180-3 compliant SHA-256 one-way hash algorithm on a 512-bit message block. The message block consists of a 160-bit secret, a 160-bit challenge and 192 bits of constant data. Optionally, the 64-bit ROM ID replaces 64 of the 192 bits of constant data used in the hash operation. 16 bits out of the 160-bit secret and 16 bits of ROM ID are programmable - 8 bits each in metal and 8 bits each in OTP bits.

The host and the MAX86140 both calculate the result based on a mutually known secret. The result of the hash operation is known as the message authentication code (MAC) or message digest. The MAC is returned by the MAX86140 for comparison with the host's MAC. Note that the secret is never transmitted on the bus and thus cannot be captured by observing bus traffic. Each authentication attempt is initiated by the host system by writing a 160-bit random challenge into the SHA memory address space 0x00h to 0x09h. The host then issues the compute MAC or compute MAC with ROM ID command. The MAC is computed per FIPS 180-3, and stored in address space 0x00h to 0x0Fh overwriting the challenge value.

Note that the results of the authentication attempt are determined by host verification. Operation of the MAX86140 is not affected by authentication success or failure.

Sequence of operation is as follows:

- Enable SHA\_DONE Interrupt
- Enable SHA\_EN bit
- Write 160-bit random challenge value to RAM using registers MEM\_IDX and MEM\_DATA.
- Write command, with ROM ID (0x35) or without ROM ID (0x36) to SHA\_CMD register.
- Write 1 to SHA\_START and 1 to SHA\_EN bit.
- Wait for SHA\_DONE interrupt.
- Read 256 MAC value from RAM using registers MEM\_IDX and MEM\_DATA.
- Compare MAC from MAX86140 wth Host's pre- calculated MAC.
- Check PASS or FAIL
- Disable SHA\_EN bit (Write 0 to SHA\_EN bit).

| VALUE | ENUMERATION | DECODE                     |
|-------|-------------|----------------------------|
| 0x0   |             | Authentication is disabled |
| 0x1   |             | Authentication is enabled  |

#### SHA\_START

The bit gets cleared after authentication completes. The valid command (0x35 or 0x36) should be written to the SHA\_CMD register and challenge value should be written to the RAM by Host before writing 1 to this bit.

#### **Memory Control (0xF2)**

| BIT         | 7 | 6 | 5 | 4 | 3 | 2 | 1             | 0           |
|-------------|---|---|---|---|---|---|---------------|-------------|
| Field       | - | _ | - | _ | - | _ | MEM_WR_<br>EN | BANK_SEL    |
| Reset       | - | _ | - | - | - | - | 0x0           | 0x0         |
| Access Type | _ | _ | _ | _ | _ | _ | Write, Read   | Write, Read |

#### MEM\_WR\_EN

Enable write access to Memory through SPI.

| VALUE | ENUMERATION | DECODE                                 |
|-------|-------------|----------------------------------------|
| 0x0   |             | Writing to Memory via SPI is disabled. |
| 0x1   |             | Writing to Memory via SPI is enabled   |

#### BANK\_SEL

Selects the memory bank for reading and writing.

Burst reading or writing the memory past 0xFF automatically increments BANK\_SEL to 1.

| VALUE | ENUMERATION | DECODE                                |  |  |  |  |
|-------|-------------|---------------------------------------|--|--|--|--|
| 0x0   |             | Select Bank 0, address 0x00 to 0xFF   |  |  |  |  |
| 0x1   |             | Select Bank 1, address 0x100 to 0x17f |  |  |  |  |

#### Memory Index (0xF3)

| BIT         | 7 | 6            | 5 | 4      | 3    | 2 | 1 | 0 |  |  |
|-------------|---|--------------|---|--------|------|---|---|---|--|--|
| Field       |   | MEM_IDX[7:0] |   |        |      |   |   |   |  |  |
| Reset       |   | 0x0          |   |        |      |   |   |   |  |  |
| Access Type |   |              |   | Write, | Read |   |   |   |  |  |

#### **MEM IDX**

Index to Memory for reading and writing. The memory is 384 bytes, and is divided into two banks - Bank 0 from 0x00 to 0xFF and Bank 1 is from 0x100 to 0x17F. The bank is selected by the BANK\_SEL register bit. MEM\_IDX is the starting address for burst writing to or reading from memory. Burst accessing the memory past 0xFF accesses Bank 1. The memory address saturates at 0x17F.

#### Memory Data (0xF4)

| BIT         | 7 | 6             | 5 | 4         | 3         | 2 | 1 | 0 |  |
|-------------|---|---------------|---|-----------|-----------|---|---|---|--|
| Field       |   | MEM_DATA[7:0] |   |           |           |   |   |   |  |
| Reset       |   | 0x0           |   |           |           |   |   |   |  |
| Access Type |   |               |   | Write, Re | ead, Dual |   |   |   |  |

#### MEM\_DATA

Data to be written or data read from Memory

Reading this register does not automatically increment the register address. So burst reading this register read the same register over and over, but the address to the Memory autoincrements until BANK\_SEL becomes 1 and MEM\_IDX becomes 0x7F.

#### Part ID (0xFF)

| BIT         | 7            | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|--------------|---|---|---|---|---|---|---|
| Field       | PART_ID[7:0] |   |   |   |   |   |   |   |
| Reset       | 0x24         |   |   |   |   |   |   |   |
| Access Type | Read Only    |   |   |   |   |   |   |   |

#### PART\_ID

This register stores the part identifier for the chip.

| PARTID | MAX #    | # OF PPG CHANNELS |
|--------|----------|-------------------|
| 0x24   | MAX86140 | 1                 |

### **Typical Application Circuit**



### **Ordering Information**

| PART NUMBER  | TEMP RANGE     | PIN-PACKAGE                                               | CONFIGURATION              |
|--------------|----------------|-----------------------------------------------------------|----------------------------|
| MAX86140ENP+ | -40°C to +85°C | 20-pin WLP, 2.048mm x 1.848mm, 5 x 4,<br>0.4mm ball pitch | Single Channel Optical AFE |

#### MAX86140

### Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor for Wearable Health

### **Revision History**

| REVISION<br>NUMBER | REVISION DATE | DESCRIPTION     | PAGES<br>CHANGED |
|--------------------|---------------|-----------------|------------------|
| 0                  | 5/17          | Initial release | _                |

For pricing, delivery, and ordering information, please contact Maxim Direct at 1-888-629-4642, or visit Maxim Integrated's website at www.maximintegrated.com.

Maxim Integrated cannot assume responsibility for use of any circuitry other than circuitry entirely embodied in a Maxim Integrated product. No circuit patent licenses are implied. Maxim Integrated reserves the right to change the circuitry and specifications without notice at any time. The parametric values (min and max limits) shown in the Electrical Characteristics table are guaranteed. Other parametric values quoted in this data sheet are provided for guidance.