# Product Document ### **Datasheet** DS000693 # TMF8820/21/28 # **Multizone Time-of-Flight Sensor** v5-00 • 2022-Apr-14 ## **Abstract** The TMF8820/21/28 is a dToF (direct time of flight) wide field of view optical distance sensor module achieving up to 5000 mm target detection distance and has up to 3x3, 4x4, 3x6 or 8x8 zones. # **Content Guide** | 1 | General Description 3 | |----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------| | 1.1<br>1.2<br>1.3 | Key Benefits & Features3Applications5Block Diagram5 | | 2 | Ordering Information 6 | | 3 | Pin Assignment7 | | 3.1<br>3.2 | Pin Diagram7 Pin Description8 | | 4 | Absolute Maximum Ratings 9 | | 5 | Electrical Characteristics 10 | | 6 | Typical Operating Characteristics13 | | 6.1 | 4x4 Zones Operating Mode (only TMF8821 | | 6.2 | and TMF8828)15 8x8 Zones Operating Mode (only TMF8828)16 | | 7 | Functional Description 17 | | 7.1<br>7.2<br>7.3<br>7.4<br>7.5<br>7.6 | General Operating Description17Timing Diagrams18Calibration19Algorithm Performance21Typical Optical Characteristics33I²C Interface35 | | 8 | Register Description 38 | | 8.1<br>8.2 | Register Overview | | 8.3 | appid=0x03, any cid_rid - Main Application Registers46 | | 8.4 | appid=0x03, cid_rid=0x10 - Measurement Results 56 | | 8.5 | appid=0x03, cid_rid=0x16 - Configuration Page | | |---------------------------------|----------------------------------------------------------------------|----------------| | 8.6 | appid=0x03, cid_rid=0x17/0x18 - User Defined SPAD Configuration | | | 8.7 | appid=0x03, cid_rid=0x19 - Factory Calibration | | | 8.8 | appid=0x03, cid_rid=0x81 – Raw Data Histograms | | | 8.9 | appid=0x80 – Bootloader Registers | | | 9 | Application Information | 87 | | 9.1<br>9.2<br>9.3<br>9.4<br>9.5 | SchematicPCB LayoutExternal ComponentsPCB Pad LayoutSoftware Drivers | 89<br>90<br>90 | | 10 | Package Drawings & Markings | 92 | | 11 | Tape & Reel Information | 93 | | 12 | Soldering & Storage Information | 94 | | 12.1<br>12.2 | Soldering InformationStorage Information | | | 13 | Laser Eye Safety | 97 | | 14 | Revision Information | 98 | | 15 | Legal Information | 99 | # 1 General Description The TMF8820, TMF8821 & TMF8828 are a family of direct time-of-flight (dToF) sensors available in a small footprint modular package with integrated Vertical Cavity Surface Emitting Laser (VCSEL). The dToF device is based on SPAD, TDC and histogram technology and achieves 5000 mm detection range. Due to its lens on the SPAD, it supports 3x3, 4x4, 3x6 and 8x8 multizone output data and a very wide, dynamically adjustable, field of view. A multi-lens-array (MLA) inside the package above the VCSEL widens up the FoI (field of illumination). All processing of the raw data is performed on-chip and the TMF8820/21/28 provide distance information together with confidence values on its I<sup>2</sup>C interface. TMF8820 3x3 zones operation TMF8821 3x3, 4x4 and 3x6 zones operation TMF8828 3x3, 4x4, 3x6, and 8x8 zones operation #### Information (only pertains to TMF8828) The TMF8828 requires unique firmware (different from TMF8820/21/28) that will only operate on the TMF8828. The TMF8828 has two operating modes. It can operate as a TMF8820/21/28 (3x3, 4x4, or 3x6 zones) or in the TMF8828 mode which has 8x8 zones. In the TMF8828 mode, the device implements the 8x8 zone functionality as a sequence of four time-multiplexed measurements of 4x4 zones (like TMF8821). As such, the factory calibration sequence, loading the calibration data, reading the result measurements, and the optional histogram readouts must be performed four times in sequence by the host (please see the Host Driver Communication manual for details). The maximum measurement cycle rate in the TMF8828 mode is 15 Hz with 125 k iterations. Slower cycle rates with an increased number of iterations are possible. ## 1.1 Key Benefits & Features The benefits and features of TMF8820/21/28, Multizone Time-of-Flight Sensor, are listed below: Figure 1: Added Value of Using TMF8820/21/28 | Benefits | Features | |-------------------------------------------------------|--------------------------------------------| | Small footprint fits within narrow bezel applications | Modular package - 2.0 mm x 4.6 mm x 1.4 mm | | Detecting objects in a very wide field of view | 63° Fol/FoV | | Benefits | Features | |---------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------| | Enable new applications like click to focus, object tracking, presence detection | TMF8828: Multizone with 3x3, 4x4, 3x6 and 8x8 zones TMF8821: Multizone with 3x3, 4x4 and 3x6 zones TMF8820: Multizone with 3x3 zones | | Within ±3% / ±10 mm of measurement (accuracy); no multipath and no multiple object problems as for iToF | Time-to-Digital Converter (TDC) Direct Time-of-Flight Measurement | | Better accuracy detects reliably closest object Minimum distance 10 mm Maximum distance 5000 mm | Single Photon Avalanche Photodiode (SPAD) Histogram based architecture | | No complex calibration | Dynamic cover glass calibration | | Compensates for dirt on glass | Reliable operation under demanding use cases | | Improved accuracy over temperature and life | Reference SPAD | | Make better decisions | Distance and signal quality reported | | Class 1 eye safe | Fast VCSEL driver with protection | | Integration flexibility | I <sup>3</sup> C tolerant - operate on a shared I <sup>2</sup> C / I <sup>3</sup> C bus | | Longer battery life | 141 mW power consumption at 30 Hz operation 8 μA power consumption standby current (keep memory) 2 μA power-down current consumption (EN=0) | # 1.2 Applications The device is ideal for use with applications including: - Distance measurement for camera autofocus Laser Detect Autofocus LDAF (mobile phone) - Presence detection (computing and communication) - Object detection and collision avoidance (robotics) - Light curtain (industrial) ## 1.3 Block Diagram The functional blocks of this device are shown below: Figure 2 : Functional Blocks of TMF8820/21/28 # 2 Ordering Information | Ordering Code | Package | Marking | Delivery Form | Delivery<br>Quantity | Note | |---------------|---------|---------------|----------------------------|----------------------|--------------------| | TMF8820-1AM | | | Tape & Reel<br>(7" reels) | 500 pcs/reel | - 3x3 zones | | TMF8820-1A | _ | | Tape & Reel<br>(13" reels) | 4000 pcs/reel | - 3x3 zuries | | TMF8821-1AM | - ' | tical 8-digit | Tape & Reel<br>(7" reels) | 500 pcs/reel | 3x3, 4x4 and | | TMF8821-1A | | tracecode | Tape & Reel<br>(13" reels) | 4000 pcs/reel | 3x6 zones | | TMF8828-1AM | _ | | Tape & Reel<br>(7" reels) | 500 pcs/reel | 3x3, 4x4, 3x6 | | TMF8828-1A | _ | | Tape & Reel<br>(13" reels) | 4000 pcs/reel | – and 8x8<br>zones | # 3 Pin Assignment # 3.1 Pin Diagram Figure 3: Pin Locations Top Through View (not to scale) ## 3.2 Pin Description Figure 4: Pin Description of TMF8820/21/28 | Pin Number | Pin Name | Pin Type <sup>(1)</sup> | Description | |------------|----------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------| | 1 | VDDC | PWR | Charge pump supply voltage (3 V) – connect all VDD pins together; add a capacitor GRM155R70J104KA01 (0402 X7R 0.1 $\mu$ F 6.3V) to GND | | 2 | GNDC | GND | Charge pump ground; connect all ground pins together | | 3 | GPIO0 | I/O | General purpose input/output; default tristate; connect to GND if not used | | 4 | INT | OD | Interrupt. Open-drain output; connect to GND if not used | | 5 | SCL | IN | I <sup>2</sup> C serial clock | | 6 | SDA | I/O | I <sup>2</sup> C serial data | | 7 | VDD | PWR | Chip supply voltage (3 V) – connect all VDD pins together; add a capacitor GRM155R70J104KA01 (0402 X7R 0.1 µF 6.3 V) to GND | | 8 | GND | GND | Chip ground; connect all ground pins together | | 9 | EN | IN | Enable input active high; setting to low forces the device into shutdown and all memory content is lost; connect to VDD if not used | | 10 | GPIO1 | I/O | General purpose input/output; default tristate; connect to GND if not used | | 11 | GNDV | GND | VCSEL ground; connect all ground pins together | | 12 | VDDV | PWR | VCSEL supply voltage (3 V) – connect all VDD pins together; add a capacitor GRM155R70J104KA01 (0402 X7R 0.1 µF 6.3 V) to GND | | | | | | (1) Explanation of abbreviations: IN Digital input pin I/O Digital Input output pin OD Open drain output pin GND ground supply pin PWR Power Supply pin #### Information SDA, SCL, INT and EN have no diode to any VDD supply. Therefore even with VDD=0 V they do not block the interrupt line or $I^2C$ bus. GPIO0 and GPIO1 are push/pull output and have a diode to VDD; therefore if VDD is not powered, GPIO0 and GPIO1 shall not be driven from outside. # 4 Absolute Maximum Ratings Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of the device at these or any other conditions beyond those indicated under "Operating Conditions" is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Figure 5 Absolute Maximum Ratings of TMF8820/21/28 | Symbol | Parameter | Min | Max | Unit | Comments | | | | | |---------------------|----------------------------------------|------|--------------------|------|---------------------------------------------------------------------------------------------------|--|--|--|--| | Electrical Pa | Electrical Parameters | | | | | | | | | | $V_{DDMAX}$ | 3 V Supply Voltage to Ground | -0.3 | 3.6 <sup>(1)</sup> | V | Pins VDDV, VDDC, VDD | | | | | | $V_{GND}$ | Ground | ( | 0.0 | V | Pins GNDV, GNDC, GND | | | | | | V <sub>IOMAX</sub> | Digital I/O Terminal Voltage | -0.3 | 3.6 | V | SCL, SDA, INT and EN;<br>has no internal diode to<br>VDD | | | | | | $V_{IO\_GPIO\_MAX}$ | Interface Digital I/O terminal voltage | -0.3 | VDD+0.3<br>max 3.6 | V | GPIO0, GPIO1 has an internal diode to VDD | | | | | | I <sub>SCR</sub> | Input Current (latch-up immunity) | ± | ± 100 | | JEDEC JESD78E | | | | | | Electrostatio | Discharge | | | | | | | | | | ESD <sub>HBM</sub> | Electrostatic Discharge HBM | ± 2 | 2000 | V | JS-001-2017 | | | | | | ESD <sub>CDM</sub> | Electrostatic Discharge CDM | ± | 500 | V | JEDEC JS-002-2018 | | | | | | Temperature | Ranges and Storage Conditions | | | | | | | | | | T <sub>STRG</sub> | Storage Temperature Range | -40 | 85 | °C | | | | | | | T <sub>BODY</sub> | Package Body Temperature | | 260 | °C | IPC/JEDEC J-STD-020(2) | | | | | | RH <sub>NC</sub> | Relative Humidity (non-condensing) | 5 | 85 | % | | | | | | | MSL | Moisture Sensitivity Level | 3 | | | Represents a maximum floor life time of 168h with T <sub>A</sub> <30 °C and RH <sub>NC</sub> <60% | | | | | <sup>(1)</sup> Limit supply rise to 1 V/μs <sup>(2)</sup> The reflow peak soldering temperature (body temperature) is specified according to IPC/JEDEC J-STD-020 "Moisture/Reflow Sensitivity Classification for Nonhermetic Solid State Surface Mount Devices." The lead finish for Pb-free leaded packages is "Matte Tin" (100 % Sn) # **5** Electrical Characteristics Device parameters are guaranteed at nominal conditions unless otherwise noted. While the device is operational across the temperature range, functionality will vary with temperature. The parameters with Min and Max values are guaranteed with production tests or SQC (Statistical Quality Control) methods. Figure 6: Electrical Characteristics of TMF8820/21/28 | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-----|------| | VDD | 3 V supply voltage | Pins VDDV, VDDC and VDD | 2.7 | 3.0 | 3.3 | V | | VIO | I/O supply voltage | Supply voltage for external pull-up for SCL, SDA and INT. | 1.62 | 1.8 | 3.3 | V | | Т <sub>АМВ</sub> | Operating ambient temperature | | -30 | 23 | 70 | °C | | Current Consur | nption | | | | | | | I <sub>POWER_DOWN</sub> | Power down current | Pin EN=0; state: power down;<br>T <sub>AMB</sub> =23°C | | 2 | 10 | μΑ | | Istandby | Standby current | Current consumption for PON=0, wakeup by special I <sup>2</sup> C command, only retention RAM keeps content; state: standby; I/O pins not toggling Only register 0xE0 (ENABLE) accessible by I <sup>2</sup> C interface when in this mode. | | 8 | | μΑ | | I <sub>STANDBY_TIMED</sub> | Standby timed current | Current consumption for waiting for measurement period to expire. goto_standby_timed = 1, low_power_osc_on = 1 Only register 0xE0 (ENABLE) accessible by I <sup>2</sup> C interface when in | | 34 | | μА | | | | this mode | | | | | | I <sub>WAIT</sub> | Wait current | Wakeup by I <sup>2</sup> C or timer, all<br>memories keep content, CPU off,<br>oscillator on;<br>state: wait | | 216 | | μΑ | | I <sub>ACTIVE</sub> | Active current | Current consumption for CPU running at 80 MHz, VCSEL and TDC off state: active – histogram processing | | 2.8 | | mA | | I <sub>ACTIVE_</sub> RANGING | Active current for ranging (VCSEL emitting light) | Current consumption for CPU running at 80 MHz, VCSEL and TDC on state: active – ranging | | 57 | | mA | | Average Curren | nt Consumption for Run | ning Application | | | | | | P <sub>RANGING_AVG</sub> | Average power consumption | Default settings with 550 k iterations, 3x3 mode, output data rate 30 Hz | | 141 | | mW | | P <sub>RANGING_AVG_LP</sub> | Average power consumption low power | Output data rate 30 Hz, 3x3 mode, 50 k iterations | | 19 | | mW | | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |----------------------------------|----------------------------------------------|---------------------------------------------------------------------------------|------|-----------------------|------|------| | I/O Levels – Ove | er Temperature and Sup | ply | | | | | | I <sub>LEAK</sub> | Leakage current to VDD or GND | SDA, SCL, GPIO0/1, EN, INT | -5 | | 5 | μΑ | | V <sub>IH</sub> | Input voltage high | SDA, SCL, GPIO0/1, EN | 1.26 | | 3.3 | V | | V <sub>IL</sub> | Input voltage low | SDA, SCL, GPIO0/1, EN | 0 | | 0.54 | V | | V <sub>OL2mA</sub> | Output voltage low | SDA, INT, 2 mA sink | 0 | | 0.36 | V | | $V_{OL4mA}$ | Output voltage low | SDA. INT, 4 mA sink | 0 | | 0.6 | V | | I <sub>DRIVE_H</sub> | Output current high | 1 V applied on GPIO0/1 | 3.6 | | | mA | | I <sub>DRIVE_L</sub> | Output current low | 1 V applied on GPIO0/1 | 3.6 | | | mA | | Timings – over | Temperature and Supply | / | | | | | | f <sub>clk</sub> | RC oscillator | All internal timings are derived from this clock | 4.85 | 5 | 5.15 | MHz | | f <sub>CPUclk</sub> | Maximum operating frequency of CPU | The CPU can be switched between fclk and fclk*16 | | fclk * 16<br>(80 MHz) | | MHz | | VCSEL <sub>CLK</sub> | Clock frequency of<br>VCSEL clock | | | 17.77 | | MHz | | t <sub>POR</sub> | Power on time | EN=1 to ready for I <sup>2</sup> C command | | | 2 | ms | | | Time to download | For 1 MHz I <sup>2</sup> C speed [TMF8820/21] | | 50 | | ms | | t <sub>FW_DOWNLOAD</sub> | firmware | For 1 MHz I <sup>2</sup> C speed [TMF8828] | | 100 | | ms | | t <sub>FIRST_MEAS_COLD</sub> | Time from cold start to first measurement | From EN=0->1 (power down) to first measurement result; default settings (33 ms) | | 190 | | ms | | t <sub>FIRST_MEAS_WARM</sub> | Time from warm start to first measurement | From standby to first measurement result; default settings (33 ms) | | 60 | | ms | | t <sub>SWITCH_to_8820/8821</sub> | Time to switch to TMF8820/21 mode | From command 0x65 to CMD_STAT to first measurement result [TMF8828] | | 65 | | ms | | t <sub>SWITCH_to_8828</sub> | Time to switch to TMF8828 mode | From command 0x6C to CMD_STAT to first measurement result [TMF8828] | | 115 | | ms | | I <sup>2</sup> C Interface – o | ver Temperature and Su | ıpply | | | | | | f <sub>SCLK</sub> | SCL clock frequency | | 0 | 400 | 1000 | kHz | | t <sub>BUF</sub> | Bus free time<br>between a STOP and<br>START | | 0.5 | | | μs | | t <sub>HD:STA</sub> | Hold time<br>(Repeated) Start | | 0.26 | | | μs | | $t_{LOW}$ | LOW period of SCL<br>Clock | | 0.5 | | | μs | | t <sub>HIGH</sub> | HIGH period of SCL clock | | 0.26 | | | μs | | t <sub>SU:STA</sub> | Setup time for a<br>Repeated START | | 0.26 | | | μs | | t <sub>HD:DAT</sub> | Data hold time | | 0 | | | μs | | t <sub>SU:DAT</sub> | Data setup time | | 50 | | | ns | | -30.DA1 | | | | | | | | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |-----------------------------------|---------------------------------------------------|----------------------------------------------------|---------|--------------|------------|---------| | t <sub>F</sub> | Fall time of both SDA and SCL | | 20 | | 120 | ns | | Optical Paramet | ters | | | | | | | Fol | Field of view of the illuminator main area | Diagonal, FWHM <sup>(3)</sup> of radiant intensity | See sec | tion 7.5.2 | | | | Optical Multizor | ne Parameters | | | | | | | SPAD <sub>X</sub> | Delta in angle of single SPAD in x | In optical center | | 2.4 | | degrees | | SPAD <sub>Y</sub> | Delta in angle of single SPAD in y <sup>(1)</sup> | In optical center | | 5.6 | | degrees | | Optical Stack Re | Optical Stack Requirements | | | | | | | GLASS <sub>TRANSPAR</sub><br>ENCY | Glass transparency<br>@ 940 nm | The device can work with IR inked or clear glass | 85 | 90 | | % | | XTALK <sub>SYSTEM</sub> | System Crosstalk | Measured in final application | See am | s OSRAM opti | cal design | guide | <sup>(1)</sup> Due to SPADs with too high dark count, which are disabled by production test (screamer detection), need to use always at least two SPADs next to each other. <sup>(2)</sup> FWHM – full width half maximum. # **6 Typical Operating Characteristics** Following operating characteristics are measured with calibrated devices with full optical stack. The ambient light is measured on the target. The data is perpendicular scaled for the non-center zones. Figure 7: 350 Lux Fluorescent Light 18% Grey Card 3x3, 33°x32° FoV Center Zone, 30 Hz Figure 8: Figure 7 Zoomed to 0 mm – 1000 mm Figure 9: 350 Lux Fluorescent Light 18% Grey Card 3x3, 33°x32° FoV, Edge Zone, 30 Hz Figure 10: 350 Lux Fluorescent Light 18% Grey Card 3x3, 33°x32° FoV, Corner Zone, 30 Hz Figure 11: 140 Lux HAL (1 Lux sunlight) 18% Grey Card 3x3, 33°x32° FoV Center Zone, 30 Hz Figure 12: 700 Lux HAL (5 k Lux sunlight) 18% Grey Card 3x3, 33°x32° FoV Center Zone, 30 Hz Figure 13: 1400 Lux HAL (10 k Lux sunlight) 18% Grey Card 3x3, 33°x32° FoV Center Zone, 30 Hz Figure 14: Reported Distance During a Temperature Sweep from 70 °C to -30 °C with a Fixed Target in the Oven ## 6.1 4x4 Zones Operating Mode (only TMF8821 and TMF8828) Figure 15: 350 Lux Fluorescent Light 18% Grey Card 4x4, 41°x52° FoV Center Zone, 15 Hz Figure 16: Figure 15 Zoomed to 0 mm - 1000 mm Figure 17: 350 Lux Fluorescent Light 18% Grey Card 4x4, 41°x52° FoV, Edge Zone, 15 Hz Figure 18: 350 Lux Fluorescent Light 18% Grey Card 4x4, 41°x52° FoV, Corner Zone, 15 Hz # 6.2 8x8 Zones Operating Mode (only TMF8828) Figure 19: 350 Lux Fluorescent Light 18% Grey Card 8x8, 41°x52° FoV Center Zone, 15 Hz Figure 20: Figure 19 Zoomed to 0 mm - 1000 mm Figure 21: 350 Lux Fluorescent Light 18% Grey Card 8x8, 41°x52° FoV, Edge Zone, 15 Hz Figure 22: 350 Lux Fluorescent Light 18% Grey Card 8x8, 41°x52° FoV, Corner Zone, 15 Hz # 7 Functional Description ### 7.1 General Operating Description The TMF8820/21/28 operating principle uses a pulse train of VCSEL pulses defined by the iteration setting. These pulses are spread using a MLA (micro lens array) to illuminate the FoI (field of illumination). An object reflects these rays back to the TMF8820/21/28 receiver optics lens and onto a SPAD (single photon avalanche detector) array. A TDC (time to digital converter) measures now the time from emission of these pulses to their arrival and accumulates the hits into bins inside a histogram. As TMF8820/21 sends 550 k pulses (default settings), the output of the TDC is a full histogram as shown in Figure 23: Figure 23: Example Target Histogram and Reference Histogram (Blue) The large blue peak (clipped due to scaling for measurement peaks) in the histogram shows the reference peak histogram. A SPAD, which is located in the cavity of the VCSEL, generates this target peak. The target detection algorithm uses this peak together with the crosstalk peaks at bin 15 in the measurements channels to calculate zero distance. All measurement histograms show a crosstalk peak around bin 15 and the actual target peak at bin 50 – the algorithm has an internal calibration to calculate from bins to time, which the algorithm converts to distance using speed of light. In above example, the time from bin 15 to bin 50 represents a target distance of 2 m. The internal processor (ARM M0+ ®) executes the ams OSRAM algorithm on these histograms to calculate the target distance of the object. The output of this calculation is the distance in [mm] presented on the I<sup>2</sup>C interface for each of the zones. #### 7.1.1 Multizone / Multi-Object Functionality The SPADs below the receiver lens are in focus of this lens. Therefore, depending on the location of the object, the different zones see different areas of the scene as shown in the raw histogram graph in Figure 24: Figure 24: Multizone Histograms Example In zone3 (histogram 3) there is an additional object at 50 cm which is shown by a third peak in the histogram around bin 25. Zone3 outputs a first object at 50 cm and a second object at 2 m distance. # 7.2 Timing Diagrams Following figure shows a typical target measurement timing diagram of TMF8820/21/28: Figure 25: Timing Diagram for Ranging Period > Ranging Active + Histogram Processing If the ranging period is chosen shorter than the combined time of ranging active and histogram processing, the TMF8820/21/28 automatically runs histogram processing in parallel to ranging active: Figure 26: Timing Diagram for Ranging Period < Ranging Active + Histogram Processing #### Note: In time multiplex mode for TMF8821 (4x4 and 3x6) and TMF8828 (8x8), ranging active is executed 2 times for 3x6 and 4x4 respectively 4 times for 8x8 mode before an interrupt is sent after histogram processing. Each VCSEL burst uses the programmed number of iterations defined by register iterations[15:8] and iterations[7:0]. #### 7.3 Calibration To achieve the performance described in the next sections, the correct SPAD mask shall be set, iterations set to 4 M and calibration of the algorithm needs to be performed (cmd\_stat = 0x20). The TMF8820/21/28 shall be embedded in the final application and the cover glass including the IR ink needs to be assembled. The calibration test shall be done in a housing with minimal ambient light and no target within 40 cm in field of view of the TMF8820/21/28. #### **Attention** Set number of iterations during calibration to 4 M to ensure accuracy. Read also the optical design guide (ODG) to have the system crosstalk level in the range defined by this document. The TMF8820/21/28 generates a calibration data set, which needs to be stored on the host processor and reloaded after each power down or reset event. It shall be ensured by the optical design that the optical crosstalk values are meeting the limits defined in the TMF8820/21/28 optical design guide (ODG). Figure 27: Calibration Data Measured Crosstalk Values (Little endian format = LSB first) | l <sup>2</sup> C Address<br>(if appid=0x03,<br>cid_rid=0x19 –<br>Factory Calibration) | Offset in Calibration<br>Data File | Meaning | |---------------------------------------------------------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x2A-0x2B | 0x06-0x07 | Iterations used for calibration divided by 1024 | | | | e multiplexed mode (3x3); also for the first d 3x6); TMF8828 repeats 4x4 calibration 4 times | | 0x5C-0x5F | 0x38-0x3B | Crosstalk for reference channel – shall be ignored | | 0x60-0x63 | 0x3C-0x3F | Crosstalk for channel 1 | | 0x64-0x67 | 0x40-0x43 | Crosstalk for channel 2 | | 0x68-0x6B | 0x44-0x47 | Crosstalk for channel 3 | | 0x6C-0x6F | 0x48-0x4B | Crosstalk for channel 4 | | 0x70-0x73 | 0x4C-0x4F | Crosstalk for channel 5 | | 0x74-0x77 | 0x50-0x53 | Crosstalk for channel 6 | | 0x78-0x7B | 0x54-0x57 | Crosstalk for channel 7 | | 0x7C-0x7F | 0x58-0x5B | Crosstalk for channel 8 | | 0x80-0x83 | 0x5C-0x5F | Crosstalk for channel 9 | | | | s 1-9 only for the second measurement in time ats 4x4 calibration 4 times | | 0xB4-0xB7 | 0x90-0x93 | Crosstalk for reference channel; time multiplex – shall be ignored | | 0xB8-0xBB | 0x94-0x97 | Crosstalk for channel 1; time multiplex | | 0xBC-0xBF | 0x98-0x9B | Crosstalk for channel 2; time multiplex | | 0xC0-0xC3 | 0x9C-0x9F | Crosstalk for channel 3; time multiplex | | 0xC4-0xC7 | 0xA0-0xA3 | Crosstalk for channel 4; time multiplex | | 0xC8-0xCB | 0xA4-0xA7 | Crosstalk for channel 5; time multiplex | | 0xCC-0xCF | 0xA8-0xAB | Crosstalk for channel 6; time multiplex | | 0xD0-0xD3 | 0xAC-0xAF | Crosstalk for channel 7; time multiplex | | 0xD4-0xD7 | 0xB0-0xB3 | Crosstalk for channel 8; time multiplex | | 0xD8-0xDB | 0xB4-0xB7 | Crosstalk for channel 9; time multiplex | | 0xDC | 0xB8 | fc_status_during_cal - calibration status during factory calibration – copy of register 0x07 – 0x00 success, all other values are reporting an error during calibration | The host shall send the calibration data for the selected SPAD mask on each power-up of the TMF8820/21/28 and after each change of the SPAD mask using cmd\_stat = 0x19, prior to execution of the ams OSRAM algorithm. #### Attention Calibration shall be done individually for all different SPAD masks used in operation of the device. ### 7.4 Algorithm Performance The algorithm performance is measured using the driver supplied by ams OSRAM and using the latest firmware included in TMF882x\_Driver\_Linux\_v\*.zip. Download the latest firmware from **ams** website: - For TMF8820 see https://ams.com/tmf8820 - For TMF8821 see https://ams.com/tmf8821 - For TMF8828 see https://ams.com/tmf8828 The driver automatically performs clock skew correction (use host clock to compensate for the TMF8820/21/28 internal clock drift) to achieve the accuracy. See also section 9.5 for available drivers. Performance parameters apply at nominal supply and temperature. #### 7.4.1 SPAD Mask and Mode Selection The SPAD mask selection (register spad\_map\_id see Figure 113) defines the assignment of the SPADs to the individual zones – due to the lens above the SPADs, the FoV (field of view) of the sensor is also defined by the SPAD mask as shown in Figure 29. The ranging period shown in Figure 28 is depending on the operating mode, which is selected by spad\_map\_id and the iterations setting, set by register iterations. To achieve fastest ranging period set the report period in ms (register period) below ranging period to ensure that there will be no wait time. Figure 28: Ranging Period vs. Iterations and Operating Mode | Operating Mode | Iterations | Ranging Period With<br>No Wait Time Programmed | |----------------|------------|------------------------------------------------| | | 50 k | 6.1 ms | | 3x3 | 550 k | 32.2 ms | | | 4000 k | 230 ms | | Operating Mode | Iterations | Ranging Period With<br>No Wait Time Programmed | |----------------|------------|------------------------------------------------| | | 50 k | 13 ms | | 3x6 or 4x4 | 550 k | 65 ms | | | 4000 k | 460 ms | | | 50 k | 26 ms | | 8x8 | 550 k | 129 ms | | | 4000 M | 920 ms | Figure 29: Relation of SPADs to FoV – Zone 3,6,9 from spad\_map\_id=1 (3x3 mode, 33°x32° FoV) FoV of a SPAD or a zone can be calculated with, assuming center of zone is in optical center: #### **Equation 1:** $$FoV \ [^{\circ}] = 2 * atan \frac{size \ of \ zone \ or \ SPAD}{2 * \ focal \ distance}$$ Where focal distance = $400 \mu m$ Size of a single SPAD is 16.8 μm in x-direction and 38.8 μm in y-direction. There are several pre-defined SPAD masks available as shown in Figure 113 and drawn in Figure 30 for 3x3 mode and Figure 31 for 4x4 and 3x6 mode and Figure 32 for 8x8 mode: Figure 30: Zones Configuration of Pre-Programmed SPAD Maps for 3x3 Mode Operation Note: Use the checkerboard SPAD masks especially for high ambient light conditions. Figure 31: Zones Configuration of Pre-Programmed SPAD Maps for 4x4 and 3x6 Mode Operation Figure 32: Zones Configuration of Pre-Programmed SPAD Maps for 8x8 Mode Operation Except in TMF8828 mode, the customer can design an own SPAD mask and assign SPADs to channels individually. In TMF8828 mode, the SPAD mask is fixed and cannot be changed. There are following constrains for these SPAD masks: - Use spad\_map\_id=14 for single measurement up to 9 zones and spad\_map\_id=15 for time multiplexed measurement up to 18 zones - The SPAD mask has a maximum size of 18x10. - SPAD mapping and SPAD enable mask shall have the exact same size. - Channel 0 is reserved for the reference channel and shall not be used in a SPAD mask. - The resulting SPAD mask plus offset shall not exceed 18x12 example: An 18x10 size SPAD mask has to have x\_offset\_2=0 (18 is already the limit) but can have a y-offset of +/-1 SPAD. Please note that the actual register value y\_offset\_2 is multiplied by 2 so, +2 or -2 is the actual value stored to y\_offset\_2 to obtain an offset of +1 respectively -1. - In each used channel, there shall be at least two adjacent SPADs (can be in any direction). - A single row shall not use channel 1 and channel 8 or 9 at the same time. - There needs to be at least one channel per TDC enabled otherwise electrical calibration will fail use at minimum channel (2 or 3) and (4 or 5) and (6 or 7) and (8 or 9) A complete SPAD mask consists of an enable mask, where a '1' is an enabled SPAD and a '0' is used for a disabled SPAD, and a TDC channel selection mask where the number '1'...'9' assigns this SPAD to a TDC channel. See document TMF882X\_Host\_Driver\_Communication\*.pdf for detailed explanation how to download customized SPAD maps. ams OSRAM recommends to program the SPAD mask through the device driver and read back the masks for verification. Whenever the SPAD mask selection is changed, the current calibration is no longer valid – see section 7.3. #### **CAUTION** For a user defined SPAD mask ensure that each zone has at least two adjacent SPADs enabled. Otherwise, on some devices this zone might not see any target counts at all. #### 7.4.2 Performance in 3x3 Operating Mode The algorithm reports distance information for each of the zone individually for the closest and the 2<sup>nd</sup> closest object in 1 mm steps. The algorithm performance is depending on the chosen zone: Figure 33: Zones Definition For spad\_map\_id=1 (3x3 mode, 33°x32° FoV), calibration according to section 7.3, following performance parameters apply. The reported distance is the actual distance between the device and the actual measured zone – there is no perpendicular flat target correction applied. The target covers the full FoV of the device. Figure 34: Typical Maximum Distance in 3x3 Mode, 33°x32° FoV, 550 k Iterations (30 Hz output data rate), Light on the Target Only | Target<br>Reflectivity %T<br>at 940 nm | Zone | 350 Lux LED<br>Lighting | 140 Lux<br>Halogen <sup>(1)</sup> | 700 Lux<br>Halogen <sup>(2)</sup> | 1400 Lux<br>Halogen <sup>(3)</sup> | |----------------------------------------|--------|-------------------------|-----------------------------------|-----------------------------------|------------------------------------| | | Center | 5000 mm | 4500 mm | 2000 mm | 1000 mm | | White target 90% | Edge | 5000 mm | 4000 mm | 1800 mm | 950 mm | | | Corner | 5000 mm | 3000 mm | 1500 mm | 750 mm | | | Center | 5000 mm | 3000 mm | 2000 mm | 1500 mm | | Grey target 18% | Edge | 4500 mm | 2800 mm | 1500 mm | 1400 mm | | | Corner | 4000 mm | 2000 mm | 1400 mm | 1200 mm | - (1) 140 lux halogen light represents 1 k lux sunlight - (2) 700 lux halogen light represents 5 k lux sunlight - (3) 1400 lux halogen light represents 10 k lux sunlight #### 7.4.3 Performance in 4x4 Operating Mode – Only TMF8821 and TMF8828 #### Information Please note that the zones for 4x4 operating mode are presented in zones 1-8 and 10-17; the result for zone 9 and 18 is not used. The algorithm reports distance information for each of the zone individually for the closest and the 2<sup>nd</sup> closest object in 1 mm steps. The algorithm performance is depending on the chosen zone: Figure 35: Zones Definition (TMF8821 and TMF8828) For spad\_map\_id=7 (4x4 mode, 41°x52° FoV), calibration according to section 7.3, following performance parameters apply. The reported distance is the actual distance between the device and the actual measured zone – there is no perpendicular flat target correction applied. The target covers the full FoV of the device. Figure 36: Typical Maximum Distance in 4x4 Mode, 41°x52° FoV, 550 k Iterations (15 Hz output data rate), Light on the Target Only | Target<br>Reflectivity %T<br>at 940 nm | Zone | 350 Lux LED<br>Lighting | 140 Lux<br>Halogen <sup>(1)</sup> | 700 Lux<br>Halogen <sup>(2)</sup> | 1400 Lux<br>Halogen <sup>(3)</sup> | |----------------------------------------|--------|-------------------------|-----------------------------------|-----------------------------------|------------------------------------| | | Center | 5000 mm | 3500 mm | 2000 mm | 1000 mm | | White target 90% | Edge | 3000 mm | 1400 mm | 900 mm | 500 mm | | | Corner | 2900 mm | 1300 mm | 800 mm | 400 mm | | | Center | 4000 mm | 2500 mm | 1500 mm | 1400 mm | | Grey target 18% | Edge | 1500 mm | 1200 mm | 800 mm | 700 mm | | | Corner | 1400 mm | 1100 mm | 700 mm | 600 mm | - (1) 140 lux HAL represents 1k lux sunlight - (2) 700 lux HAL represents 5k lux sunlight - (3) 1400 lux HAL represents 10k lux sunlight #### 7.4.4 Performance in 8x8 Operating Mode – Only TMF8828 #### Information Please note that the zones for 8x8 operating mode are presented in zones 1-8 and 10-17; the result for zone 9 and 18 is not used. The algorithm reports distance information for each of the zone individually for the closest and the 2<sup>nd</sup> closest object in 1 mm steps. The algorithm performance is depending on the chosen zone: Figure 37: Zones Definition (TMF8828) After calibration according to section 7.3, the following performance parameters apply. The reported distance is the actual distance between the device and the actual measured zone – there is no perpendicular flat target correction applied. The target covers the full FoV of the device. Figure 38: Typical Maximum Distance in 8x8 Mode, 41°x52° FoV, 125 k Iterations (15 Hz output data rate), Light on the Target Only | Target<br>Reflectivity %T<br>at 940 nm | Zone | 350 Lux LED<br>Lighting | 140 Lux<br>Halogen <sup>(1)</sup> | 700 Lux<br>Halogen <sup>(2)</sup> | 1400 Lux<br>Halogen <sup>(3)</sup> | |----------------------------------------|--------|-------------------------|-----------------------------------|-----------------------------------|------------------------------------| | | Center | 4400 mm | 2000 mm | 1300 mm | 1000 mm | | White target 90% | Edge | 1500 mm | 900 mm | 500 mm | 400 mm | | | Corner | 900 mm | 600 mm | 300 mm | 300 mm | | Target<br>Reflectivity %T<br>at 940 nm | Zone | 350 Lux LED<br>Lighting | 140 Lux<br>Halogen <sup>(1)</sup> | 700 Lux<br>Halogen <sup>(2)</sup> | 1400 Lux<br>Halogen <sup>(3)</sup> | |----------------------------------------|--------|-------------------------|-----------------------------------|-----------------------------------|------------------------------------| | | Center | 2000 mm | 1500 mm | 1000 mm | 800 mm | | Grey target 18% | Edge | 800 mm | 600 mm | 400 mmm | 300 mm | | | Corner | 500 mm | 400 mm | 300 mm | 200 mm | - (1) 140 lux HAL represents 1k lux sunlight - (2) 700 lux HAL represents 5k lux sunlight - (3) 1400 lux HAL represents 10k lux sunlight #### 7.4.5 Short Range High Accuracy Mode From EVM release 3v52 onwards, the TMF8820/21/28 have a short range and high accuracy mode. This operating mode enhances the accuracy for a detection range up to 1000 mm. Use this operating mode only if best accuracy for short range is needed as this operating mode reduces maximum detection distance as shown by Figure 34, Figure 36 and Figure 38 by approximately 50 % and clips it to 1000 mm but greatly enhances accuracy. The mode can be enabled by setting of register active\_range. Please download the relevant calibration data after switching the operating mode. Figure 39: Accuracy Short Range Mode of TMF8820/21/28 | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |------------------|--------------------------------|-----------------------------------------------|-----|--------|-----|------| | | Minimum | Grey target 18% | | 10 | | mm | | dміn | detection<br>distance | White target 90% | | 25 | | mm | | | | 10 mm to 20 mm | | ± 10 | | mm | | | Accuracy of | 20 mm to 200 mm | | ± 5 | | mm | | daccuracy3x3,4x4 | detection for 3x3 and 4x4 mode | 200 mm to 1000 mm; all except corner zones | | ± 2.0 | | % | | | | 200 mm to 1000 mm; corner zones | | ± 2.5 | | % | | | | 10 mm to 20 mm | | ± 10 | | mm | | | | 20 mm to 40 mm | | ± 5 | | mm | | daccuracy8x8 | Accuracy of<br>detection for | 40 mm to 100 mm | | -10/+5 | | mm | | | 8x8 mode | 100 mm to 200 mm | | ± 5 | | mm | | | | 200 mm to 1000 mm;<br>all except corner zones | | ± 2.0 | | % | | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |------------|-----------|------------------------------------------|-----|----------------|-----|------| | | | 200 mm to 1000 mm; corner zones | | ± 3.0 | | % | | dprecision | Precision | ± 2 sigma (95%),<br>350 lux LED lighting | | 2 mm<br>+ 0.5% | | | #### **Attention** The short range, high accuracy mode needs an individual calibration per SPAD map – see document TMF882X\_Host\_Driver\_Communication\*.pdf for detailed explanation of this calibration. #### 7.4.6 Accuracy / Precision Long Range Mode (default) Figure 40: Accuracy and Precision Parameters Long Range Mode (TMF8820/21 mode – 550 k iterations) | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |------------------------|----------------------------|------------------------------------------|-----|----------------|-----|------| | d <sub>MIN</sub> | Minimum detection distance | | | 10 | | mm | | | | 10 mm to 20 mm | | ± 19 | | mm | | | Accuracy of detection | 20 mm to 50 mm,<br>grey target | | ± 10 | | mm | | daccuracy | | 50 mm to 250 mm | | ± 15 | | mm | | | | 250 mm to 333 mm | | ± 10 | | mm | | | | ≥ 333 mm | | ± 3 | | % | | d <sub>PRECISION</sub> | Precision | ± 2 sigma (95%),<br>350 lux LED lighting | | 2 mm<br>+ 0.5% | | | Please note that above parameters are typical parameters and perpendicular flat target correction applied. Figure 41: Accuracy and Precision Parameters Long Range Mode (TMF8828 mode – 125 k iterations) | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |------------------|----------------------------|----------------|-----|--------|-----|------| | d <sub>MIN</sub> | Minimum detection distance | | | 10 | | mm | | daccuracy | Accuracy of detection | 10 mm to 20 mm | | -4/+22 | | mm | | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |------------|-----------|------------------------------------------|-----|----------------|-----|------| | | | 20 mm to 50 mm,<br>grey target | | -3/+18 | | mm | | | | 50 mm to 250 mm | | -16/+7 | | mm | | | | 250 mm to 333 mm | | -12/+7 | | mm | | | | ≥ 333 mm | | ± 5 | | % | | dPRECISION | Precision | ± 2 sigma (95%),<br>350 lux LED lighting | | 2 mm<br>+ 0.5% | | | Please note that above parameters are typical parameters on clear cover glass and perpendicular flat target correction applied. #### 7.4.7 Confidence For each detected target, the TMF8820/21/28 provides a confidence result. The confidence result is the signal to noise ratio (SNR) of the detected peak in the histogram. Signal = Peak value in the histogram Noise = Noise from the device and ambient light = sqrt (baseline level of histogram) The confidence value is an 8-bit value which supports two encodings: #### **Linear Encoding** Selected by setting register bit logarithmic\_confidence = 0. The values for confidence represents directly SNR and are clipped at 255. #### Logarithmic Encoding Selected by setting register bit logarithmic\_confidence = 1. The values 0...40 represent directly SNR. Values above 40 are exponentially scaled with a growth rate of 5.36%. Following c-like code fragment converts from the coded value 'confidence' to the actual value 'exp\_conf': #define CONF\_BREAKPOINT 40 #define EXP\_GROWTH\_RATE 1.053676f ## 7.5 Typical Optical Characteristics #### 7.5.1 VCSEL Internal protection ensures no single point of failure will cause the VCSEL to violate the Class 1 Laser Safety. Laser Safety Class 1 #### 7.5.2 Fol / FoV VCSEL Field of Illumination (Fol) ``` 47x57° (70° diagonal calc.) full width from 5% of maximum up to max. 41x47° (60° diagonal calc.) 1/e^2 ``` • 30x32° (43° diagonal calc.) FWHM #### Information The smaller value (x/y) for FoI is always into the direction of the SPADs. FWHM ... Full width half maximum Figure 42: Field of Illumination Shown in Pseudocolors in [%] of Max Range The sensor field is view (FoV) depends on the chosen spad\_map\_id: dToF Sensor Field of View (FoV) 41x52° (63° diagonal calc.) spad\_map\_id=6 or 7 33x32° (45° diagonal calc.) spad\_map\_id=1 see Figure 30 and Figure 31 – fully customizable FoV. Figure 43: FoV/FoI of TMF8820/21/28 #### 7.5.3 Optical Filter Characteristics The on-chip optical filter blocks most of the ambient light and improves the performance especially with sunlight. It is possible to add another optical filter on top to even further improve sunlight performance. • FWHM 92 nm Passband Center Wavelength 940 nm (filter only) ### 7.6 I<sup>2</sup>C Interface The TMF8820/21/28 is controlled by an I2C bus, one interrupt pin and two GPIO pins. Additionally see ams OSRAM device driver and/or application note TMF882X\_Host\_Driver\_Communication\_\*.pdf for a detailed explanation of the I<sup>2</sup>C communication itself. The device uses I<sup>2</sup>C serial communication protocol for communication. The device supports 7-bit chip addressing (default: 0x41) and standard, fast mode and fast mode plus modes. Read and Write transactions comply with the standard set by Philips (now NXP). For a complete description of the I<sup>2</sup>C protocol, please review the NXP I<sup>2</sup>C design specification. Figure 44: I<sup>2</sup>C Timings The TMF8820/21/28 support following I<sup>2</sup>C operating modes: • Standard mode – up to 100 kBit/s Fast-mode – up to 400 kBit/s Fast-mode-plus – up to 1 MBit/s Figure 45: I<sup>2</sup>C Symbol Definition | Symbol | Definition | RW | Note | |---------|-----------------------------------------------------------------------|--------|--------------------| | S | Start condition after stop | R | 1-bit | | Sr | Repeated start (start condition end without preceding stop condition) | R | 1-bit | | ADR | Slave address 7 bits = default 0x41 | R | Slave address | | WA | Word address | R | 8-bit | | A | Acknowledge | W | 1-bit | | N | No Acknowledge | R | 1-bit | | Data | Data/write | R or W | 8-bit | | Data(n) | Data/read | W | 8-bit | | Р | Stop condition | R | 1-bit | | WA++ | Slave increment word address | R | During acknowledge | Internal to the device, an 8-bit buffer stores the register address location of the byte to read or write. This buffer auto-increments upon each byte transfer and is retained between transaction events (i.e. valid even after the master issues a P (Stop condition) and the I<sup>2</sup>C bus is released). During consecutive Read transactions, the future/repeated I<sup>2</sup>C Read transaction may omit the memory address byte normally following the chip address byte; the buffer retains the last register address +1. A Write transaction consists of a S, ADR, 0 (R/W flag), WA, Data (n), and P. Following each byte (9th clock pulse) the slave places an A or NA (ACK/NACK) on the bus. If NACK is transmitted by the slave, the master may issue a P. Figure 46: Byte Write and Page Write Commands A Read transaction consists of a S, ADR, 0 (R/W flag), WA, Sr, ADR, 1 (R/W flag), Data(n) and P. Following all but the final byte the master places an A (ACK) on the bus (9<sup>th</sup> clock pulse). Termination of the Read transaction is indicated by a N (NACK) being placed on the bus by the master, followed by STOP. Figure 47: Random Read and Sequential Read Command (example shows 2 bytes) The default I<sup>2</sup>C address is 0x41. The address can be changed after power-up. Use the enable pin to enable only one device at a time to provide unique device addresses – see section 9.1.1. The device is I<sup>3</sup>C tolerant – therefore it can coexist with I<sup>3</sup>C devices on the same bus. TMF8820/21/28 communicates in legacy I<sup>2</sup>C mode of the I<sup>3</sup>C bus. #### Attention During standby and standby timed mode, only register 0xE0 (ENABLE) is accessible by the I<sup>2</sup>C interface. # 8 Register Description ## 8.1 Register Overview Please note that the $I^2C$ register table uses pages. Therefore, the content of the registers depends on the page select register app\_id and cid\_rid. Figure 48: Register Overview | Addr | Name | <d7></d7> | <d6></d6> | <d5></d5> | <d4></d4> | <d3></d3> | <d2></d2> | <d1></d1> | <d0></d0> | |-----------|--------------------------------|----------------|---------------|---------------|-----------|---------------|-----------|---------------|-----------| | Any appid | , any cid_rid – Registers alwa | ıys available | ) | | | | | | | | 0x00 | APPID | appid | | | | | | | | | 0x01 | MINOR | minor | | | | | | | | | 0xE0 | ENABLE | 0 | cpu_re<br>ady | powerup | _select | | | | pon | | 0xE1 | INT_STATUS | 0 | int7 | int6 | 0 | int4 | 0 | int2 | 0 | | 0xE2 | INT_ENAB | 0 | int7_en<br>ab | int6_en<br>ab | 0 | int4_en<br>ab | 0 | int2_en<br>ab | 0 | | 0xE3 | ID | | | 0 | 0 | 1 | 0 | 0 | 0 | | 0xE4 | REVID | | | | | | rev_id | | | | appid=0x0 | 3, any cid_rid - Main Applica | ion Registe | rs | | | | | | | | 0x02 | PATCH | patch | patch | | | | | | | | 0x03 | BUILD_TYPE | build | build | | | | | | | | 0x04 | APPLICATION_STATUS | app_status | | | | | | | | | 0x05 | MEASURE_STATUS | measure_status | | | | | | | | | 0x06 | ALGORITHM_STATUS | alg_status | | | | | | | | | 0x07 | CALIBRATION_STATUS | fc_status | | | | | | | | | 80x0 | CMD_STAT | cmd_stat | | | | | | | | | 0x09 | PREV_CMD | prev_cmd | | | | | | | | | 0x10 | MODE (TMF8828 ONLY) | mode | | | | | | | | | 0x0A | LIVE_BEAT | live_beat | | | | | | | | | 0x19 | ACTIVE_RANGE | active_ran | ge | | | | | | | | 0x1C | SERIAL_NUMBER_0 | serial_num | nber[7:0] | | | | | | | | 0x1D | SERIAL_NUMBER_1 | serial_num | nber[15:8] | | | | | | | | 0x1E | SERIAL_NUMBER_2 | serial_num | nber[23:16] | | | | | | | | 0x1F | SERIAL_NUMBER_3 | serial_num | nber[31:24] | | | | | | | | 0x20 | CONFIG_RESULT | cid_rid | | | | | | | | | 0x21 | TID | tid | | | | | | | | | 0x22 | SIZE_LSB | size[7:0] | | | | | | | | | 0x23 | SIZE_MSB | size[15:8] | | | | | | | | | Addr | Name | <d7></d7> | <d6></d6> | <d5></d5> | <d4></d4> | <d3></d3> | <d2></d2> | <d1></d1> | <d0></d0> | |------------|--------------------------------|--------------|---------------|-----------|-----------|-----------|-----------|-----------|-----------| | appid=0x03 | , cid_rid=0x10 - Measureme | nt Results | | | | | | | | | 0x24 | RESULT_NUMBER | number | number | | | | | | | | 0x25 | TEMPERATURE | temperature | | | | | | | | | 0x26 | NUMBER_VALID_RESUL<br>TS | valid_resu | valid_results | | | | | | | | 0x28 | AMBIENT_LIGHT_0 | ambient[7: | :0] | | | | | | | | 0x29 | AMBIENT_LIGHT_1 | ambient[1 | 5:8] | | | | | | | | 0x2A | AMBIENT_LIGHT_2 | ambient[23 | 3:16] | | | | | | | | 0x2B | AMBIENT_LIGHT_3 | ambient[3 | 1:24] | | | | | | | | 0x2C | PHOTON_COUNT_0 | photon_co | ount[7:0] | | | | | | | | 0x2D | PHOTON_COUNT_1 | photon_co | ount[15:8] | | | | | | | | 0x2E | PHOTON_COUNT_2 | photon_co | ount[23:16] | | | | | | | | 0x2F | PHOTON_COUNT_3 | photon_co | ount[31:24] | | | | | | | | 0x30 | REFERENCE_COUNT_0 | reference_ | _count[7:0] | | | | | | | | 0x31 | REFERENCE_COUNT_1 | reference_ | _count[15:8] | | | | | | | | 0x32 | REFERENCE_COUNT_2 | reference_ | _count[23:16 | 6] | | | | | | | 0x33 | REFERENCE_COUNT_3 | reference_ | _count[31:24 | 1] | | | | | | | 0x34 | SYS_TICK_0 | sys_tick[7: | :0] | | | | | | | | 0x35 | SYS_TICK_1 | sys_tick[1 | 5:8] | | | | | | | | 0x36 | SYS_TICK_2 | sys_tick[23 | 3:16] | | | | | | | | 0x37 | SYS_TICK_3 | sys_tick[3 | 1:24] | | | | | | | | 0x38 | RES_CONFIDENCE_0 | confidence | e0 | | | | | | | | 0x39 | RES_DISTANCE_0_LSB | distance0[ | 7:0] | | | | | | | | 0x3A | RES_DISTANCE_0_MSB | distance0[ | 15:8] | | | | | | | | 0x3B | RES_CONFIDENCE_1 | confidence | e1 | | | | | | | | 0x3C | RES_DISTANCE_1_LSB | distance1[ | 7:0] | | | | | | | | 0x3D | RES_DISTANCE_1_MSB | distance1[ | 15:8] | | | | | | | | | | | | | | | | | | | 0xA1 | RES_CONFIDENCE_35 | confidence | e35 | | | | | | | | 0xA2 | RES_DISTANCE_35_LSB | distance35 | 5[7:0] | | | | | | | | 0xA3 | RES_DISTANCE_35_MS<br>B | distance35 | 5[15:8] | | | | | | | | appid=0x03 | , cid_rid=0x16 – Configuration | on Page | | | | | | | | | 0x24 | PERIOD_MS_LSB | period[7:0] | ] | | | | | | | | 0x25 | PERIOD_MS_MSB | period[15:8 | 8] | | | | | | | | 0x26 | KILO_ITERATIONS_LSB | iterations[7 | 7:0] | | | | | | | | 0x27 | KILO_ITERATIONS_MSB | iterations[1 | 15:8] | | | | | | | | 0x28 | INT_THRESHOLD_LOW_<br>LSB | int_thresho | old_low[7:0] | | | | | | | | 0x29 | INT_THRESHOLD_LOW_<br>MSB | int_thresho | old_low[15:8 | 3] | | | | | | | Addr | Name | <d7></d7> | <d6></d6> | <d5></d5> | <d4></d4> | <d3></d3> | <d2></d2> | <d1></d1> | <d0></d0> | |---------------|--------------------------------|--------------------------------|--------------------------|--------------------------|-----------|--------------------------|-------------------------|-------------------|---------------------------| | 0x2A | INT_THRESHOLD_HIGH_<br>LSB | int_thresho | old_high[7: | 0] | | | | | | | 0x2B | INT_THRESHOLD_HIGH_<br>MSB | int_thresho | nt_threshold_high[15:8] | | | | | | | | 0x2C | INT_ZONE_MASK_0 | int_zone_n | nt_zone_mask[7:0] | | | | | | | | 0x2D | INT_ZONE_MASK_1 | int_zone_n | nask[15:8] | | | | | | | | 0x2E | INT_ZONE_MASK_2 | | | | | | | int_zone<br>7:16] | e_mask[1 | | 0x2F | INT_PERSISTENCE | int_persiste | ence | | | | | | | | 0x30 | CONFIDENCE_THRESHO<br>LD | confidence | _threshold | i | | | | | | | 0x31 | GPIO_0 | driver_stre | ngth0 | | pre_dela | ay0 | gpio0 | | | | 0x32 | GPIO_1 | driver_stre | ngth1 | | pre_dela | ay1 | gpio1 | | | | 0x33 | POWER_CFG | goto_sta<br>ndby_tim<br>ed | low_po<br>wer_os<br>c_on | keep_p<br>Il_runni<br>ng | | allow_<br>osc_ret<br>rim | pulse_i<br>nterrup<br>t | | | | 0x34 | SPAD_MAP_ID | | spad_map_id | | | | ap_id | | | | 0x35 | ALG_SETTING_0 | logarith<br>mic_conf<br>idence | | | | distanc<br>e_mod<br>e | distanc<br>es | | | | 0x36-<br>0x38 | | Reserved - | - keep at 0 | ) | | | | | | | 0x39 | HIST_DUMP | | | | | | | | histogr<br>am | | 0x3A | SPREAD_SPECTRUM | Reserved - | – keep at C | ) | | | spread_s | pectrum_f | actor | | 0x3B | I2C_SLAVE_ADDRESS | 7bit_slave_ | _address | | | | | | 0 | | 0x3C | OSC_TRIM_VALUE_LSB | osc_trim_v | ralue[7:0] | | | | | | | | 0x3D | OSC_TRIM_VALUE_MSB | | | | | | | | osc_tri<br>m_valu<br>e[8] | | 0x3E | I2C_ADDR_CHANGE | | | | | gpio_cha | ange_ma | gpio_ch<br>ue | ange_val | | appid=0x | 03, cid_rid=0x17/0x18 - User c | defined SPA | D Configu | ration | | | | | | | 0x24 | SPAD_ENABLE_FIRST | spad_enab | ole_first | | | | | | | | | | | | | | | | | | | 0x41 | SPAD_ENABLE_LAST | spad_enab | ole_last | | | | | | | | 0x42 | SPAD_TDC_FIRST | spad_tdc_f | first | | | | | | | | | ··· | | | | | | | | | | 0x8C | SPAD_TDC_LAST | spad_tdc_l | ast | | | | | | | | 0x8D | SPAD_X_OFFSET_2 | x_offset_2 | | | | | | | | | 0x8E | SPAD_Y_OFFSET_2 | y_offset_2 | | | | | | | | | 0x8F | SPAD_X_SIZE | x_size | | | | | | | | | 0x90 | SPAD_Y_SIZE | y_size | | | | | | | | | appid=0x | 03, cid_rid=0x19 - Factory Cal | ibration | | | | | | | | | 0x24 | FACTORY_CALIBRATIO<br>N_FIRST | factory_cal | ibration_fi | rst – see se | ction 7.3 | | | | | | Addr | Name | <d7> <d6> &lt;</d6></d7> | D5> <d4></d4> | <d3></d3> | <d2></d2> | <d1></d1> | <d0></d0> | |-----------|------------------------------|-------------------------------------------------------|---------------------------------|-------------------|----------------|--------------|--------------------------| | | | | | | | | | | 0x60-63 | CROSSTALK_ZONE1 | crosstalk_amplitude_zon | e1, 32-bit value | , LSB first (I | ittle-endian) | | | | 0x64-67 | CROSSTALK_ZONE2 | crosstalk_amplitude_zon | e2, 32-bit value | , LSB first (I | ittle-endian) | | | | 0x68-6B | CROSSTALK_ZONE3 | crosstalk_amplitude_zon | e3, 32-bit value | , LSB first (I | ittle-endian) | | | | 0x6C-6F | CROSSTALK_ZONE4 | crosstalk_amplitude_zon | e4, 32-bit value | , LSB first (I | ittle-endian) | | | | 0x70-73 | CROSSTALK_ZONE5 | crosstalk_amplitude_zon | e5, 32-bit value | , LSB first (I | ittle-endian) | | | | 0x74-77 | CROSSTALK_ZONE6 | crosstalk_amplitude_zon | e6, 32-bit value | , LSB first (I | ittle-endian) | | | | 0x78-7B | CROSSTALK_ZONE7 | crosstalk_amplitude_zon | e7, 32-bit value | , LSB first (I | ittle-endian) | | | | 0x7C-7F | CROSSTALK_ZONE8 | crosstalk_amplitude_zon | e8, 32-bit value | , LSB first (I | ittle-endian) | | | | 0x80-83 | CROSSTALK_ZONE9 | crosstalk_amplitude_zon | e9, 32-bit value | , LSB first (I | ittle-endian) | | | | | | | | | | | | | 0xB8-BB | CROSSTALK_ZONE1_TM<br>UX | crosstalk_amplitude_zon 4x4 mode this represents | | | | | n) – for | | 0xBC-BF | CROSSTALK_ZONE2_TM<br>UX | crosstalk_amplitude_zon | e2 time muxed, | 32-bit value | e, LSB first ( | little-endia | n) | | 0xC0-C3 | CROSSTALK_ZONE3_TM<br>UX | crosstalk_amplitude_zon | e3 time muxed, | 32-bit value | e, LSB first ( | little-endia | n) | | 0xC4-C7 | CROSSTALK_ZONE4_TM<br>UX | crosstalk_amplitude_zon | e4 time muxed, | 32-bit value | e, LSB first ( | little-endia | n) | | 0xC8-CB | CROSSTALK_ZONE5_TM<br>UX | crosstalk_amplitude_zon | e5 time muxed, | 32-bit value | e, LSB first ( | little-endia | n) | | 0xCC-CF | CROSSTALK_ZONE6_TM<br>UX | crosstalk_amplitude_zon | e6 time muxed, | 32-bit value | e, LSB first ( | little-endia | n) | | 0xD0-D3 | CROSSTALK_ZONE7_TM<br>UX | crosstalk_amplitude_zon | e7 time muxed, | 32-bit value | e, LSB first ( | little-endia | n) | | 0xD4-D7 | CROSSTALK_ZONE8_TM<br>UX | crosstalk_amplitude_zon | e8 time muxed, | 32-bit value | e, LSB first ( | little-endia | n) | | 0xD8-DB | CROSSTALK_ZONE9_TM<br>UX | crosstalk_amplitude_zon used for 3x6 mode or cu | e9 time muxed,<br>stomized SPAD | 32-bit value maps | e, LSB first ( | little-endia | n) – only | | 0xDC | CALIBRATION_STATUS_<br>FC | fc_status_during_cal - ca<br>0x07 - 0x00 success, all | | | | | | | | | | | | | | | | 0xDF | FACTORY_CALIBRATIO<br>N_LAST | factory_calibration_last | | | | | | | appid=0x0 | 3, cid_rid=0x81 – Raw data H | stograms | | | | | | | 0x24 | SUBPACKET_NUMBER | subpacket_number | | | | | | | 0x25 | SUBPACKET_PAYLOAD | subpacket_payload | | | | | | | 0x26 | SUBPACKET_CONFIG | | | | | | subpac<br>ket_co<br>nfig | | 0x27 | SUBPACKET_DATA0 | subpacket_data0 | | | | | | | | | - | | | | | | | 0xA6 | SUBPACKET_DATA127 | subpacket_data127 | | | | | | | appid=0x8 | 0 – Bootloader Registers | - | | | | | | | 0x08 | BL_CMD_STAT | bl_cmd_stat | | | | | | | 0x09 | BL_SIZE | bl_size | | | | | | | | <del>_</del> - | | | | | | | | Addr | Name | <d7></d7> | <d6></d6> | <d5></d5> | <d4></d4> | <d3></d3> | <d2></d2> | <d1></d1> | <d0></d0> | |------------|---------|------------|--------------|-------------|------------|------------|-------------|-------------|-----------| | 0x0A | BL_DATA | bl_data0 . | bl_data1 | 27 - size c | lepends or | n bl_cmd_s | tat – can b | e from 0 to | 128 | | | | | | | | | | | | | after data | BL_CSUM | bl_csum - | - actual loc | ation depe | nds on bl_ | cmd_stat - | can be fro | om 0x0A to | 0x8B | ## 8.2 Any app\_id - Register Description for All Application IDs ## 8.2.1 APPID Register (Address 0x00) Figure 49: APPID Register | Addr: 0x00 APPID | | | | | | | | |------------------|----------|---------|--------|--------------------------------|-------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | | | | 0 | RO | Currently running application: | | | | | | | | | | Measurement application running (=application major revision) | | | | 7:0 | appid | | | 0x03 | Please allow 6 ms after RAMREMAP_RESET before reading this value. | | | | | | | | 0x80 | Bootloader running | | | #### 8.2.2 MINOR Register (Address 0x01) Figure 50: MINOR Register | Addr: 0x01 | | MINOR | | | |------------|----------|---------|--------|------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | minor | 0 | RO | Application minor or bootloader revision Please allow 6 ms after RAMREMAP_RESET before reading this value. | ## 8.2.3 ENABLE Register (Address 0xE0) Figure 51: ENABLE Register | A alab | *· 0×E0 | ENABLE | | | | |--------|----------------|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Addi | r: 0xE0 | ENABLE | | | | | Bit | Bit Name | Default | Access | Bit Desc | ription | | 6 | cpu_ready | 0 | RO | then only<br>useable,<br>used.<br>Bit gets s<br>therefore | eady to handle I <sup>2</sup> C - if this bit is zero, the registers 0xE0 and above are the memory mapped I <sup>2</sup> C space is not set only explicitly by software, a functional and running firmware is try for this bit to work. | | | | | | always-o<br>This bit is<br>no effect<br>See ams | hat to do at power up. Bits reside in n domain and survive standby mode. s evaluated by software only and has on the circuit. OSRAM driver how to change a application and how to reset the 0/21/28. | | 5:4 | powerup_select | 0 | R_PUSH | Value | Description | | | | | | 0 | Default – start bootloader | | | | | | 1 | Start bootloader but do not go to sleep | | | | | | 2 | Start the application currently in RAM | | | | | | 3 | Reserved, do not use | | 0 | pon | 1 | R_PUSH | standby Activating hardware '1' is bein started a is implem reset at the an IDLE and | te oscillator 0=Ask cpu to go to g the oscillator is implemented in e. Whenever this register is '0' and a ng written, the oscillator is being and CPU receives a PON1 interrupt. It nented in the bootloader to execute a this point, but the application goes to state. The process of the important that the CPU allown all modules properly before ff the oscillator, therefore this is anted in firmware. So writing a '0' to this will trigger an internal CPU interrupt. Ware, after powering down everything, device into standby state. | ## 8.2.4 INT\_STATUS Register (Address 0xE1) Figure 52: INT\_STATUS Register | Addr: | 0xE1 | INT_STA | TUS | | |-------|----------|---------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7 | | 0 | | Reserved – leave at 0 | | 6 | int7 | 0 | R_PUSH1 | Interrupt status for one of the status registers has been set to a non-zero value Int7 status. If bit is asserted, and int7_enab is asserted as well, then the INT pin will be pulled low. Writing a '1' here will clear int7 condition. | | 5 | int6 | 0 | R_PUSH1 | Interrupt status for a received command has been handled (successfully or error) Int6 status. If bit is asserted, and int6_enab is asserted as well, then the INT pin will be pulled low. Writing a '1' here will clear int6 condition. | | 4 | | 0 | | Reserved – leave at 0 | | 3 | int4 | 0 | R_PUSH1 | Interrupt status for raw histogram is ready for readout Int4 status. If bit is asserted, and int4_enab is asserted as well, then the INT pin will be pulled low. Writing a '1' here will clear int4 condition. | | 2 | | 0 | | Reserved – leave at 0 | | 1 | int2 | 0 | R_PUSH1 | Interrupt status for measurement result is ready for readout Int2 status. If bit is asserted, and int2_enab is asserted as well, then the INT pin will be pulled low. Writing a '1' here will clear int2 condition. | | 0 | | 0 | | Reserved – leave at 0 | ## 8.2.5 INT\_ENAB Register (Address 0xE2) Figure 53: INT\_ENAB Register | Addr: 0xE2 | | INT_ENA | В | | |------------|-----------|---------|--------|-----------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7 | | 0 | | Reserved – leave at 0 | | 6 | int7_enab | 0 | RW | Interrupt enable for one of the status registers has been set to a non-zero value | | Addr: | 0xE2 | INT_ENA | ιB | | |-------|-----------|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | | | | | 0=Disabled, 1=Enabled; INT output is active if int7 flag is "1" | | 5 | int6_enab | 0 | RW | Interrupt enable for a received command has been handled (successfully or error) 0=Disabled, 1=Enabled; INT output is active if int6 flag is "1" | | 4 | | 0 | | Reserved – leave at 0 | | 3 | int4_enab | 0 | RW | Interrupt enable for raw histogram is ready for readout 0=Disabled, 1=Enabled; INT output is active if int4 flag is "1" | | 2 | | 0 | | Reserved – leave at 0 | | 1 | int2_enab | 0 | RW | Interrupt enable for measurement result is ready for readout 0=Disabled, 1=Enabled; INT output is active if int2 flag is "1" | | 0 | | 0 | | Reserved – leave at 0 | ## 8.2.6 ID Register (Address 0xE3) Figure 54: ID Register | Addr: 0xE3 ID | | | | | |---------------|----------|---------|--------|-----------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 5:0 | id | 08 | RO | Chip ID, reads 08h – do not rely on register bits 6 and 7 of this register. | ## 8.2.7 REVID Register (Address 0xE4) Figure 55: ID Register | Addr: 0 | )xE4 | REVID | | | |---------|----------|---------|--------|------------------| | Bit | Bit Name | Default | Access | Bit Description | | 2:0 | rev id | NA | RO | Chip revision ID | ## 8.3 appid=0x03, any cid\_rid - Main Application Registers Following registers are only available if appid=0x03 (=measurement application). These registers are always available for appid=0x03 independently of register cid\_rid. #### 8.3.1 PATCH Register (Address 0x02) Figure 56: PATCH Register | Addr: 0x02 | | PATCH | | | |------------|----------|---------|--------|----------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | patch | 0 | RO | Application patch revision Please allow 6 ms after RAMREMAP_RESET before reading this value. | #### 8.3.2 BUILD\_TYPE Register (Address 0x03) Figure 57: BUILD\_TYPE Register | Addr: 0x03 | | BUILD_TYPE | | | |------------|----------|------------|--------|----------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | build | 0 | RO | Application build revision Please allow 6 ms after RAMREMAP_RESET before reading this value. | ## 8.3.3 APPLICATION\_STATUS Register (Address 0x04) Figure 58: **APPLICATION\_STATUS** Register | Addı | r: 0x04 | APPLICA | TION_STA | TUS | | | |------|------------------|---------|----------|-----------------|------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | | | | | | Status ir | nformation about the application | | | 7:0 | 7:0 app_status 0 | | RO | Value | Description | | | | | | | 0x00 | SUCCESS - application has no error | | | Addr: 0x04 | | APPLICATION_STATUS | | | | | | |------------|----------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Desc | cription | | | | | | | | 0x01 | ERR_BIST - histogram RAM BIST returned more than 1 error in at least 1 TDC RAM and cannot be repaired | | | | | | | | 0x02 | ERR_APP_CANT_STOP_MEASURE - the application could not terminate the measurement state machine. A hard shutdown of the measurement state machine was done | | | | | | 0x03 | ERR_APP_TIMER_OUT_OF_RANGE - upon wakeup from timed sleep the timer value was out of range. Internal program error (maybe RAM lost content) | | | | | | | | | | 0x04 | ERR_UNEXPECTED_RESET - host triggered a CPU reset or SW did call SystemReset | | | | | | | | 0x05 | WARNING_NO_FUSES_FOUND - fuses have not been programmed | | | ## 8.3.4 MEASURE\_STATUS Register (Address 0x05) Figure 59: MEASURE\_STATUS Register | Addr: 0x05 | | MEASURE_STATUS | | | | | | | |------------|-------------|----------------|--------|---------|---------------------------------------------------------------------------------------------|--|--|--| | Bit | Bit Name | Default | Access | Bit Des | Bit Description | | | | | | | | | Status | information about the measurement | | | | | | | | | Value | Description | | | | | | | | | 0x00 | SUCCESS – measurement state machine has no error | | | | | | | 0 | RO | 0x11 | ERR_MEASURE_VCSEL - VCSEL eye safety failed | | | | | 7:0 | measure_sta | | | 0x12 | ERR_MEASURE_BDV - failed to find a breakdown voltage | | | | | | | | | 0x13 | Deprecated | | | | | | | | - | 0x14 | Deprecated | | | | | | | | | 0x15 | ERR_MEASURE_CFG_TOO_MANY - tried to set a third configuration | | | | | | | | | 0x16 | ERR_MEASURE_NOT_STARTED - tried to start a measurement before configuring the state machine | | | | | Addr: 0x05 MEASURE_STATUS | | | E_STATUS | 5 | | | |---------------------------|----------|---------|----------|-----------------|------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | | | | | | 0x17 | ERR_MEASURE_BUFFER_RETURN - tried to return a buffer twice to the state machine | | | | | | | 0x18 | ERR_MEASURE_TDC_LOCKUP - when this error code is set, the TDC locked up due to a wrong setting of the Spread Spectrum. | | #### 8.3.5 ALGORITHM\_STATUS Register (Address 0x06) Figure 60: ALGORITHM\_STATUS Register | Addr: 0x06 ALGORITHM_STA | | | HM_STATU | JS | | | | |--------------------------|------------|---------|----------|----------|----------------------------------------------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Des | Bit Description | | | | | | | | Status i | nformation about the algorithm | | | | | | | | Value | Description | | | | | | | | 0x00 | SUCCESS - Algorithm has no error | | | | 7:0 | alg_status | 0 | RO | 0x21 | ERR_ALGORITHM_EC_FAILED - Algorithm could not perform electrical calibration (e.g. no two peaks found) | | | | | 9 | | - | 0x22 | ERR_ALGORITHM_EC_BUFFER_ERROR – Electrical calibration function was called, but no buffer was provided | | | | | | | | 0x23 | ERR_ALGORITHM_EC_CFG_MISMATCH<br>_ERROR – Electrical calibration function<br>got mismatched config index | | | ## 8.3.6 CALIBRATION\_STATUS Register (Address 0x07) Figure 61: CALIBRATION\_STATUS Register | Addr: 0x07 | | CALIBRA | CALIBRATION_STATUS | | | | | |------------|-----------|---------|--------------------|-------------------------------------------|--|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | | | | 0 | RO | Status about the factory calibration (fc) | | | | | 7:0 | fc_status | | | Value Description | | | | | | | | | 0x00 SUCCESS - fc has no error | | | | | Addr: 0x07 | | CALIBRATION_STATUS | | | | | |------------|----------|--------------------|--------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | | | | | | 0x31 | WARNING_NO_FACTORY_CALIBRA<br>TION - No factory calibration available,<br>device performance may be degraded | | | | | | | 0x32 | WARNING_FACTORY_CALIBRATIO N_DOES_NOT_MATCH_SPAD_MAS K - Factory calibration and SPAD mask do not correlate, device performance may be degraded | | ## 8.3.7 CMD\_STAT Register (Address 0x08) Figure 62: CMD\_STAT Register | Addr: 0x08 | | CMD_ST | AT | | | |------------|----------|---------|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Des | cription | | | | | | have the | ites to this register a command. Commands e value range 0x100xFF. Device writes to ster a status. Status have the value range 0x0F | | | | | | Value | Description | | | cmd_stat | 0 | | 0x10 | CMD_MEASURE - Measure: start a cyclic measurement according to the configuration | | | | | | 0x11 | CMD_CLEAR_STATUS - Clear Status: clear all status registers (note that a new measurement clears them as well) | | 7:0 | | | RW | 0x12 | CMD_GPIO – GPIO - configure GPIO pins according to the configuration | | | | | | 0x13 | CMD_RESERVED_EC - Reserved, do not use | | | | | | 0x14 | CMD_RESERVED_AH - Reserved, do not use | | | | | | 0x15 | CMD_WRITE_CONFIG_PAGE - Write Configuration page (whatever page has been loaded to registers 0x20 and following will be written to the device) | | | | | | 0x16 | CMD_LOAD_CONFIG_PAGE_COMMON - Load Configuration Page 0 - common configuration | | Addr: 0x | <b>c</b> 08 | CMD_ST | AT | | | |----------|-------------|---------|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Des | cription | | | | | | 0x17 | CMD_LOAD_CONFIG_PAGE_SPAD_1 - Load Configuration Page 1 - SPAD configuration | | | | | | 0x18 | CMD_LOAD_CONFIG_PAGE_SPAD_2 - Load Configuration Page 2 - SPAD configuration alternate measurement | | | | | | 0x19 | CMD_LOAD_CONFIG_PAGE_FACTOR Y_CALIB - Load Configuration Page 3 - factory calibration | | | | | | 0x20 | CMD_FACTORY_CALIBRATION - Perform Factory Calibration | | | | | | 0x21 | CMD_I2C_SLAVE_ADDRESS - Command that sets the device's I <sup>2</sup> C slave address to the address specified in config page common ( see registers I2C_SLAVE_ADDRESS and I2C_ADDR_CHANGE ) | | | | | | 0x65 | Force device to TMF8820/TMF8821 mode via a cold start (TMF8828 only) | | | | | | 0x6C | Force device to TMF8828 mode via a cold start (TMF8828 only) | | | | | | 0xFE | CMD_RESET - Reset: a software system reset shall be executed | | | | | | 0xFF | CMD_STOP - Stop: Abort any ongoing measurement | | | | | | Status F | Results (0x00-0x0F) | | | | | | 0x00 | STAT_OK - Ok, command accepted and successfully executed | | | | | | 0x01 | STAT_ACCEPTED - Command accepted and being executed, must send a STOP command to halt continues execution | | | | | | 0x02 | STAT_ERR_CONFIG - ERROR configuration not accepted, ready to accept new command | | | | | | 0x03 | STAT_ERR_APPLICATION - ERROR application encountered a severe error and stopped (more details see register APPLICATION_STATUS), ready to accept new command | | | | | | 0x04 | STAT_ERR_WAKEUP_TIMED - ERROR wakeup timed, severe internal error, device should be power cycled | | Addr: 0x08 | | CMD_ST | AT | | | |------------|----------|---------|--------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Des | cription | | | | | | 0x05 | STAT_ERR_RESET_UNEXPECTED -<br>ERROR unexpected reset, severe<br>internal error, device should be power<br>cycles | | | | | | 0x06 | STAT_ERR_UNKNOWN_CMD - ERROR unknown command | | | | | | 0x07 | STAT_ERR_NO_REF_SPAD - ERROR after screamer masking no reference SPAD is selected anymore, change your enable mask | | | | | | 0x08 | reserved | | | | | | 0x09 | STAT_ERR_UNKNOWN_CID - ERROR tried to write a config page with unknown CID, ready to accept new command | | | | | | 0x0a | STAT_WARNING_CONFIG_SPAD_1_N<br>OT_ACCEPTED - WARNING writing of<br>config SPAD 1 page was ignored, as pre-<br>selected SPAD mask is configured in<br>common page | | | | | | 0x0b | STAT_WARNING_CONFIG_SPAD_2_N<br>OT_ACCEPTED - WARNING writing of<br>config SPAD 2 page was ignored, as pre-<br>selected SPAD mask, or single user<br>defined is configured in common page | | | | | | 0x0c | STAT_WARNING_OSC_TRIM_NOT_AC<br>CEPTED - WARNING new osc trim value<br>was ignored, as allow_osc_retrim was not<br>set in register POWER_CONFIG | | | | | | 0x0d | STAT_WARNING_I2C_ADDRESS_NOT _ACCEPTED - WARNING did not accept new I <sup>2</sup> C address, as GPIOs did not match switching condition | | | | | | 0x0e | STAT_ERR_UNKNOWN_MODE -<br>ERROR this mode is not supported, read<br>to accept a new command | #### 8.3.8 PREV\_CMD Register (Address 0x09) Figure 63: PREV\_CMD Register | Addr: 0x09 | | PREV_CMD | | | | |------------|----------|----------|--------|------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | prev_cmd | 0 | RO | The previously executed command by the device - RO to host | | #### 8.3.9 MODE Register (Address 0x10) Figure 64: **MODE** Register | Addr: 0x10 MODE | | | | | | |-----------------|----------|---------|--------|-----------------|----------------------| | Bit | Bit Name | Default | Access | Bit Description | | | | | 0 | RO | Currently | running application: | | 7:0 | mode | | | 0x00 | TMF8820/21/28 mode | | | | | | 80x0 | TMF8828 mode | #### 8.3.10 LIVE\_BEAT Register (Address 0x0A) Figure 65: LIVE\_BEAT Register | Addr: 0x0A | | LIVE_BE | LIVE_BEAT | | | |------------|-----------|---------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | live_beat | 0 | RO | A free running counter that counts every time the application wakes up from sleep (WFI/WFE) the value will be reset to 0 every time the device wakes up from standby or standby-timed | | #### 8.3.11 ACTIVE\_RANGE Register (Address 0x19) Figure 66: ACTIVE\_RANGE Register | Addr: 0x19 | | ACTIVE_RANGE | | | | | |------------|--------------|------------------------------|------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access Bit Description | | | | | | active_range | Depends<br>on EVM<br>release | RW | long rar<br>High Ac | ister switches between short range and nge mode – see section 7.4.5 Short Range curacy Mode - and is only implemented 1 release 3v52 or higher. | | | 7:0 | | | | 0x00 | Accuracy mode not supported (default if function is not supported) | | | | | | | 0x6E | Short range mode | | | | | | | 0x6F | Long range mode (default if function is supported) | | #### 8.3.12 SERIAL\_NUMBER\_0 Register (Address 0x1C) Figure 67: SERIAL\_NUMBER\_0 Register | Addr: 0x1C | | SERIAL_ | NUMBER_0 | ) | |------------|--------------------|---------|----------|------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | serial_number[7:0] | NA | RO | Serial number bits 0-7 | ## 8.3.13 SERIAL\_NUMBER\_1 Register (Address 0x1D) Figure 68: SERIAL\_NUMBER\_1 Register | Addr: 0x1D | | SERIAL_NUMBER_1 | | | |------------|---------------------|-----------------|--------------------------------|-------------------------| | Bit | Bit Name | | Default Access Bit Description | | | 7:0 | serial_number[15:8] | NA | RO | Serial number bits 8-15 | #### 8.3.14 SERIAL\_NUMBER\_2 Register (Address 0x1E) Figure 69: SERIAL\_NUMBER\_2 Register | Addr: 0x1E | | SERIAL_NUMBER_2 | | | |------------|----------------------|-----------------|--------|--------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | serial_number[23:16] | NA | RO | Serial number bits 16-23 | #### 8.3.15 SERIAL\_NUMBER\_3 Register (Address 0x1F) Figure 70: SERIAL\_NUMBER\_3 Register | Addr: 0x1F | | SERIAL | _NUMBER | _3 | |------------|----------------------|---------|-------------------------------|--------------------------| | Bit | Bit Name | Default | efault Access Bit Description | | | 7:0 | serial_number[31:24] | NA | RO | Serial number bits 24-31 | #### 8.3.16 CONFIG\_RESULT Register (Address 0x20) CONFIG\_RESULT is the paging register, which defines what content is accessible in registers 0x24-0xDF. Figure 71: **CONFIG\_RESULT** Register | Addr: 0x20 | | CONFIG | CONFIG_RESULT | | | | | |------------|----------|---------|---------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | | | cid rid | 0 | RO . | 0xDF; this paged into | ter defines the content of registers 0x24-<br>s is a page selection and the actual content is<br>b registers 0x24-0xDF<br>ter is modified using command triggered by<br>gister cmd_stat – do not change this register | | | | 7:0 | ciu_riu | U | | Value | Description | | | | | | | | 0x10 | MEASUREMENT_RESULT - result record of a measurement | | | | | | | | 0x16 | COMMON_CID - COMMON configuration page | | | | Addr: 0x20 | | CONFIG_RESULT | | | | | |------------|----------|---------------|--------|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | | | | | | 0x17 | SPAD_1_CID – User defined SPAD configuration page 1 (first measurement in time multiplexed mode) | | | | | | 0x18 | SPAD_2_CID – User defined SPAD configuration page 2 (2nd measurement in time multiplexed mode) | | | | | | | | 0x19 | FACTORY_CALIBRATION_CID - factory calibration page ID | | | | | | | 0x81 | HIST_RAW_CID: Raw data histogram | | #### 8.3.17 TID Register (Address 0x21) Figure 72: TID Register | Addr: ( | Dx21 | TID | | | |---------|----------|---------|--------|-------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | tid | 0 | RO | Transaction ID register; changes on every transaction | ## 8.3.18 SIZE\_LSB Register (Address 0x22) Figure 73: SIZE\_LSB Register | Addr: | Addr: 0x22 SIZE_LSB | | В | | |-------|---------------------|---------|--------|-------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | size[7:0] | 0 | RO | LSB of total packet size – together with SIZE_MSB register define the size of the payload starting from register 0x24 onwards | #### 8.3.19 SIZE\_MSB Register (Address 0x23) Figure 74: SIZE\_MSB Register | Addr: | Addr: 0x23 SIZE_ | | E_MSB | | |-------|------------------|---------|--------|-------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | size[15:8] | 0 | RO | MSB of total packet size – together with SIZE_LSB register define the size of the payload starting from register 0x24 onwards | ## 8.4 appid=0x03, cid\_rid=0x10 - Measurement Results Following registers are only available if appid=0x03 and cid\_rid=0x10 - measurement results. #### 8.4.1 RESULT\_NUMBER Register (Address 0x24) Figure 75: **RESULT\_NUMBER Register** | Addr: | 0x24 | RESULT | _NUMBER | | |-------|----------|---------|---------|----------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | number | 0 | RO | Running counter or results | #### Information Please note that in the TMF8828 mode, the lower 2 bits of RESULT\_NUMBER (1:0) report SUB-CAPTURE and the upper 6 bits (7:2) are the running counter of results. #### 8.4.2 TEMPERATURE Register (Address 0x25) Figure 76: **TEMPERATURE** Register | Addr: | Addr: 0x25 TEMPERATURE | | ATURE | | |-------|------------------------|---------|--------|-------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | temperature | 0 | RO | Temperature of the sensor DIE in °Celsius, range is -128127 | #### 8.4.3 NUMBER\_VALID\_RESULTS Register (Address 0x26) Figure 77: NUMBER\_VALID\_RESULTS Register | Addr: 0x26 | | NUMBER | NUMBER_VALID_RESULTS | | | |------------|---------------|---------|----------------------|--------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | valid_results | 0 | RO | How many zones have reported 1 or 2 results (also no-target counts as a valid result here) | | ## 8.4.4 AMBIENT\_LIGHT\_0 Register (Address 0x28) Figure 78: AMBIENT\_LIGHT\_0 Register | Addr: 0x28 | | AMBIEN <sup>-</sup> | AMBIENT_LIGHT_0 | | | | |------------|--------------|---------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | 7:0 | ambient[7:0] | 0 | RO | Summed IR ambient light received by all channels bits 0-7 Note: This is not a linear measurement of the IR light received | | | ## 8.4.5 AMBIENT\_LIGHT\_1 Register (Address 0x29) Figure 79: AMBIENT\_LIGHT\_1 Register | Addr: 0x29 | | AMBIENT_LIGHT_1 | | | |------------|---------------|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | ambient[15:8] | 0 | RO | Summed IR ambient light received by all channels bits 8-15 Note: This is not a linear measurement of the IR light received | ## 8.4.6 AMBIENT\_LIGHT\_2 Register (Address 0x2A) Figure 80: AMBIENT\_LIGHT\_2 Register | Addr: 0x2A | | AMBIENT_LIGHT_2 | | | |------------|----------------|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | ambient[23:16] | 0 | RO | Summed IR ambient light received by all channels bits 16-23 Note: This is not a linear measurement of the IR light received | #### 8.4.7 AMBIENT\_LIGHT\_3 Register (Address 0x2B) Figure 81: AMBIENT\_LIGHT\_3 Register | Addr: 0x2B | | AMBIENT_LIGHT_3 | | | |------------|----------------|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | ambient[31:24] | 0 | RO | Summed IR ambient light received by all channels bits 24-31 Note: This is not a linear measurement of the IR light received | #### 8.4.8 PHOTON\_COUNT\_0 Register (Address 0x2C) Figure 82: PHOTON\_COUNT\_0 Register | Addr: 0x2C | | PHOTON_COUNT_0 | | | |------------|-------------------|----------------|--------|--------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | photon_count[7:0] | 0 | RO | Summed weight of the target peak of the closest target and all targets within 10 cm of this target. Bits 0-7 | ## 8.4.9 PHOTON\_COUNT\_1 Register (Address 0x2D) Figure 83: PHOTON\_COUNT\_2 Register | Addr: 0x2D | | PHOTON_COUNT_1 | | | | |------------|--------------------|----------------|--------|---------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | photon_count[15:8] | 0 | RO | Summed weight of the target peak of the closest target and all targets within 10 cm of this target. Bits 8-15 | | #### 8.4.10 PHOTON\_COUNT\_2 Register (Address 0x2E) Figure 84: PHOTON\_COUNT\_2 Register | Addr: ( | Addr: 0x2E | | PHOTON_COUNT_2 | | | | |---------|---------------------|---------|----------------|----------------------------------------------------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | 7:0 | photon_count[23:16] | 0 | RO | Summed weight of the target peak of the closest target and all targets within 10 cm of this target. Bits 16-23 | | | #### 8.4.11 PHOTON\_COUNT\_3 Register (Address 0x2F) Figure 85: PHOTON\_COUNT\_3 Register | Addr: | Addr: 0x2F | | PHOTON_COUNT_3 | | | |-------|---------------------|---------|----------------|----------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | photon_count[31:24] | 0 | RO | Summed weight of the target peak of the closest target and all targets within 10 cm of this target. Bits 24-31 | | #### 8.4.12 REFERENCE\_COUNT\_0 Register (Address 0x30) Figure 86: REFERENCE\_COUNT\_0 Register | Addr: ( | Addr: 0x30 | | REFERENCE_COUNT_0 | | | |---------|----------------------|---------|-------------------|-----------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | reference_count[7:0] | 0 | RO | Weight of the reference channel peak bits 0-7 | | #### 8.4.13 REFERENCE\_COUNT\_1 Register (Address 0x31) Figure 87: REFERENCE\_COUNT\_1 Register | Addr: 0x31 | | REFERENCE_COUNT_1 | | | |------------|-----------------------|-------------------|--------|------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | reference_count[15:8] | 0 | RO | Weight of the reference channel peak bits 8-15 | #### 8.4.14 REFERENCE\_COUNT\_2 Register (Address 0x32) Figure 88: REFERENCE\_COUNT\_2 Register | Addr: 0x32 | | REFERENCE_COUNT_2 | | | |------------|------------------------|-------------------|--------|-------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | reference_count[23:16] | 0 | RO | Weight of the reference channel peak bits 16-23 | #### 8.4.15 REFERENCE\_COUNT\_3 Register (Address 0x33) Figure 89: REFERENCE\_COUNT\_3 Register | Addr: 0 | Addr: 0x33 | | REFERENCE_COUNT_3 | | | |---------|------------------------|---------|-------------------|-------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | reference_count[31:24] | 0 | RO | Weight of the reference channel peak bits 24-31 | | #### 8.4.16 SYS\_TICK\_0 Register (Address 0x34) Figure 90: SYS\_TICK\_0 Register | Addr: 0x34 | | SYS_TICK_0 | | | | |------------|-----------------------|---------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | sys_tick[7:0] 0 RO Co | System tick with a granularity of 5 MHz (200ns) - bits 0-7 do a blockread starting at 0x20 for correct update | | | | | | | U | RO | Correct timestamps will always have bit 0 set – if bit 0 is not set, the timestamp shall be ignored and not used for clock skew correction. | | #### 8.4.17 SYS\_TICK\_1 Register (Address 0x35) Figure 91: SYS\_TICK\_1 Register | Addr: ( | 0x35 | SYS_TICK_1 | | | |---------|----------------|------------|--------|--------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | sys_tick[15:8] | 0 | RO | System tick with a granularity of 5 MHz - bits 8-15 do a blockread starting at 0x20 for correct update | #### 8.4.18 SYS\_TICK\_2 Register (Address 0x36) Figure 92: SYS\_TICK\_2 Register | Addr: 0 | x36 | SYS_TICK_2 | | | |---------|-----------------|------------|--------|---------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | sys_tick[23:16] | 0 | RO | System tick with a granularity of 5 MHz - bits 16-23 do a blockread starting at 0x20 for correct update | ## 8.4.19 SYS\_TICK\_3 Register (Address 0x37) Figure 93: SYS\_TICK\_3 Register | Addr: 0x37 SYS_TICK_3 | | K_3 | | | |-----------------------|-----------------|---------|--------|---------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | sys_tick[31:24] | 0 | RO | System tick with a granularity of 5 MHz - bits 24-31 do a blockread starting at 0x20 for correct update | #### 8.4.20 RES\_CONFIDENCE\_0 Register (Address 0x38) Figure 94: **RES\_CONFIDENCE\_0** Register | Addr: 0x38 RES_ | | RES_CO | _CONFIDENCE_0 | | | |-----------------|-------------|---------|---------------|-----------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | confidence0 | 0 | RO | Confidence rating of zone 1 Range 0-255 where 0 = No object detected 255 = Highest confidence | | #### 8.4.21 RES\_DISTANCE\_0\_LSB Register (Address 0x39) Figure 95: RES\_DISTANCE\_0\_LSB Register | Addr: | 0x39 | RES_DISTANCE_0_ | | LSB | |-------|----------------|-----------------|--------|--------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | distance0[7:0] | 0 | RO | Distance result in [mm] of zone 1 bits 0-7 | #### 8.4.22 RES\_DISTANCE\_0\_MSB Register (Address 0x3A) Figure 96: RES\_DISTANCE\_0\_MSB Register | Addr: | 0x3A | RES_DISTANCE_0_MSB | | | | |-------|-----------------|--------------------|------------------------|---------------------------------------------|--| | Bit | Bit Name | Default | Access Bit Description | | | | 7:0 | distance0[15:8] | 0 | RO | Distance result in [mm] of zone 1 bits 8-15 | | #### 8.4.23 Other Confidence / Distance Results Register (Address 0x3B-0xA3) Subsequent registers store the result for confidence, distance LSB and distance MSB in same order as RES\_CONFIDENCE\_0, RES\_DISTANCE\_0\_LSB and RES\_DISTANCE\_0\_MSB for zone 2 to the last zone of the selected mode (space reserved until register 0xA3). ## 8.5 appid=0x03, cid\_rid=0x16 - Configuration Page Following registers are only available if appid=0x03 and cid\_rid=0x16 - configuration page. #### 8.5.1 PERIOD\_MS\_LSB Register (Address 0x24) Figure 97: PERIOD\_MS\_LSB Register | Addr: | Addr: 0x24 PERIOD_MS_LSB | | MS_LSB | | |-------|--------------------------|---------|--------|-----------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | period[7:0] | 33 | RW | Measurement period in milliseconds – bits 0-7 | #### 8.5.2 PERIOD\_MS\_MSB Register (Address 0x25) Figure 98: PERIOD\_MS\_MSB Register | Addr: | 0x25 | PERIOD_MS_MSB | | | |-------|--------------|---------------|--------|------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | period[15:8] | 0 | RW | Measurement period in milliseconds – bits 8-15 | #### 8.5.3 KILO\_ITERATIONS\_LSB Register (Address 0x26) Figure 99: KILO\_ITERATIONS\_LSB Register | Addr: 0 | )x26 | KILO_ITERATIONS_LSB | | | |---------|-----------------|---------------------|--------|------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | iterations[7:0] | 25 | RW | Measurement iterations times 1024 – bits 0-7 e.g. 537 represents 549888 iterations | #### 8.5.4 KILO\_ITERATIONS\_MSB Register (Address 0x27) Figure 100: KILO\_ITERATIONS\_MSB Register | Addr: 0x27 K | | KILO_ITE | KILO_ITERATIONS_MSB | | | |--------------|------------------|----------|---------------------|-------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | iterations[15:8] | 2 | RW | Measurement iterations times 1024 – bits 8-15 e.g. 537 represents 549888 iterations | | #### 8.5.5 INT\_THRESHOLD\_LOW\_LSB Register (Address 0x28) Figure 101: INT\_THRESHOLD\_LOW\_LSB Register | Addr: 0x28 | | INT_THE | INT_THRESHOLD_LOW_LSB | | | | |------------|------------------------|---------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | 7:0 | int_threshold_low[7:0] | 0 | RW | If int_persistance>0 an interrupt for a result will only be raised if any of the object distances is farer than int_threshold_low[mm] – Bits 0-7 | | | #### Information Please note that in TMF8828 mode, the device does not have the ability to generate an interrupt based on threshold excursions and as such registers at addresses from 0x28 to 0x2F are ignored. #### 8.5.6 INT\_THRESHOLD\_LOW\_MSB Register (Address 0x29) Figure 102: INT\_THRESHOLD\_LOW\_MSB Register | Addr: 0x29 | | INT_THRESHOLD_LOW_MSB | | | | |------------|-------------------------|-----------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | int_threshold_low[15:8] | 0 | RW | If int_persistance>0 an interrupt for a result will only be raised if any of the object distances is farer than int_threshold_low[mm] – Bits 8-15 | | #### Information Please note that in TMF8828 mode, the device does not have the ability to generate an interrupt based on threshold excursions and as such registers at addresses from 0x28 to 0x2F are ignored. #### 8.5.7 INT\_THRESHOLD\_HIGH\_LSB Register (Address 0x2A) Figure 103: INT\_THRESHOLD\_HIGH\_LSB Register | Addr: 0x2A | | INT_THRESHOLD_HIGH_LSB | | | | |------------|-------------------------|------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | int_threshold_high[7:0] | 0 | RW | If int_persistance>0 an interrupt for a result will only be raised if any of the object distances is closer than int_threshold_high[mm] – Bits 0-7 | | #### Information Please note that in TMF8828 mode, the device does not have the ability to generate an interrupt based on threshold excursions and as such registers at addresses from 0x28 to 0x2F are ignored. #### 8.5.8 INT\_THRESHOLD\_HIGH\_MSB Register (Address 0x2B) Figure 104: INT\_THRESHOLD\_HIGH\_MSB Register | Addr: 0x2B | | INT_THRESHOLD_HIGH_MSB | | | |------------|--------------------------|------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | int_threshold_high[15:8] | 0 | RW | If int_persistance>0 an interrupt for a result will only be raised if any of the object distances is closer than int_threshold_high[mm] – Bits 8-15 | #### Information Please note that in TMF8828 mode, the device does not have the ability to generate an interrupt based on threshold excursions and as such registers at addresses from 0x28 to 0x2F are ignored. #### 8.5.9 INT\_ZONE\_MASK\_0 Register (Address 0x2C) Figure 105: INT\_ZONE\_MASK\_0 Register | Addr: 0x2C | | INT_ZOI | INT_ZONE_MASK_0 | | | | |------------|--------------------|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | 7:0 | int_zone_mask[7:0] | 0 | RW | If int_persistance>0 an interrupt for a result will only be raised if any of the objects enabled by int_zone_mask detects a target— Bits 0-7 Bit 0 – Zone 1 Bit 1 – Zone 2 Bit 7 – Zone 8 | | | #### Information Please note that in TMF8828 mode, the device does not have the ability to generate an interrupt based on threshold excursions and as such registers at addresses from 0x28 to 0x2F are ignored. #### 8.5.10 INT\_ZONE\_MASK\_1 Register (Address 0x2D) Figure 106: INT\_ZONE\_MASK\_1 Register | Addr: 0x2D | | INT_ZON | INT_ZONE_MASK_1 | | | |------------|---------------------|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | int_zone_mask[15:8] | 0 | RW | If int_persistance>0 an interrupt for a result will only be raised if any of the objects enabled by int_zone_mask detects a target– Bits 8-15 Bit 0 – Zone 9 | | | Addr: 0x2D | | INT_ZON | INT_ZONE_MASK_1 | | | |------------|----------|---------|-----------------|-----------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | | | | | Bit 1 – Zone 10 | | | | | | | ••• | | | | | | | Bit 7 – Zone 16 | | #### Information Please note that in TMF8828 mode, the device does not have the ability to generate an interrupt based on threshold excursions and as such registers at addresses from 0x28 to 0x2F are ignored. #### 8.5.11 INT\_ZONE\_MASK\_2 Register (Address 0x2E) Figure 107: INT\_ZONE\_MASK\_2 Register | Addr: 0x2E | | INT_ZONE_MASK_2 | | | |------------|----------------------|-----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 1:0 | int_zone_mask[17:16] | 0 | RW | If int_persistance>0 an interrupt for a result will only be raised if any of the objects enabled by int_zone_mask detects a target— Bits 16-17 Bit 0 – Zone 17 Bit 1 – Zone 18 | #### Information Please note that in TMF8828 mode, the device does not have the ability to generate an interrupt based on threshold excursions and as such registers at addresses from 0x28 to 0x2F are ignored. #### 8.5.12 INT\_PERSISTENCE Register (Address 0x2F) Figure 108: **INT\_PERSISTENCE** Register | Addr: 0x2F | | INT_PERS | INT_PERSISTENCE | | | | |------------|-----------------|----------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | 7:0 | int_persistence | | | Number of consecutive measurements that find a target inside the threshold range to trigger an interrupt | | | | | | 0 | RW | O means each measurement that finds a target inside the threshold range will trigger an interrupt 1 means there have to be two consecutive measurements that find a target inside the threshold range will trigger an interrupt | | | | | | | | For interrupt masking function to work, also set distances=1 (register 0x35) and histogram=0 (register 0x39) | | | #### Information Please note that in TMF8828 mode, the device does not have the ability to generate an interrupt based on threshold excursions and as such registers at addresses from 0x28 to 0x2F are ignored. #### 8.5.13 CONFIDENCE\_THRESHOLD Register (Address 0x30) Figure 109: **CONFIDENCE\_THRESHOLD** Register | Addr: 0x30 | | CONFIDENCE_THRESHOLD | | | | |------------|----------------------|----------------------|--------|---------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | confidence_threshold | 6 | RW | Only objects which have a confidence level equal or higher than this will be reported | | ## 8.5.14 GPIO\_0 Register (Address 0x31) Figure 110: GPIO\_0 Register | Addr: 0x31 | | GPIO_0 | | | | | |------------|------------------|---------|--------|---------------------------------------------------|---------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | | 7:6 | driver_strength0 | 0 | RW | Pin GPIO0 driver strength setting | | | | | | | | Value | Description | | | | | | | 0 | Default setting | | | | | | | 1 | 2x driving strength | | | | | | | 2 | 3x driving strength | | | | | | | 3 | 4x driving strength | | | | | 0 | RW | Pin GPIO0 pre-delay setting only for gpio0=3 or 4 | | | | | | | | Value | Description | | | 4.0 | pre_delay0 | | | 0 | No delay | | | 4:3 | | | | 1 | GPIO0 is asserted 100 μs before the VCSEL pulse | | | | | | | 2 | GPIO0 is asserted 200 μs before the VCSEL pulse | | | | gpio0 | 0 | RW | Pin GPIO0 configuration | | | | | | | | Value | Description | | | | | | | 0 | Tristate | | | | | | | 1 | Input active high | | | | | | | 2 | Input active low | | | 2:0 | | | | 3 | Output active low when VCSEL is pulsing – do not set gpio1 to 3 or 4 if this is used | | | | | | | 4 | Output active high when VCSEL is pulsing – do not set gpio1 to 3 or 4 if this is used | | | | | | | 5 | Output always high | | | | | | | 6 | Output always low | | ## 8.5.15 GPIO\_1 Register (Address 0x32) Figure 111: GPIO\_1 Register | Addr: 0x32 | | GPIO_1 | | | | | |------------|------------------|---------|--------|---------------------------------------------------|---------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | | | driver_strength1 | 0 | RW | Pin GPIO1 driver strength setting | | | | | | | | Value | Description | | | 7:6 | | | | 0 | Default setting | | | | | | | 1 | 2x driving strength | | | | | | | 2 | 3x driving strength | | | | | | | 3 | 4x driving strength | | | | | | RW | Pin GPIO1 pre-delay setting only for gpio0=3 or 4 | | | | | | | | Value | Description | | | 4.0 | pre_delay1 | 0 | | 0 | No delay | | | 4:3 | | | | 1 | GPIO1 is asserted 100 μs before the VCSEL pulse | | | | | | | 2 | GPIO1 is asserted 200 μs before the VCSEL pulse | | | | gpio1 | 0 | RW | Pin GPIC | O1 configuration | | | | | | | Value | Description | | | | | | | 0 | Tristate | | | | | | | 1 | Input active high | | | | | | | 2 | Input active low | | | 2:0 | | | | 3 | Output active low when VCSEL is pulsing – do not set gpio0 to 3 or 4 if this is used | | | | | | | 4 | Output active high when VCSEL is pulsing – do not set gpio0 to 3 or 4 if this is used | | | | | | | 5 | Output always high | | | | | | | 6 | Output always low | | ## 8.5.16 POWER\_CFG Register (Address 0x33) Figure 112: POWER\_CFG Register | Add | Addr: 0x33 | | POWER_CFG | | | | |-----|--------------------|---------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | 7 | goto_standby_timed | 0 | RW | If possible go to standby timed to save power when waiting for measurement period to expire (PERIOD_MS_*) | | | | 6 | low_power_osc_on | 0 | RW | Use low power oscillator in standby timed mode | | | | 5 | keep_pll_running | 0 | RW | In idle mode keep PLL running | | | | 4 | | 0 | RW | Reserved – keep at 0 | | | | 3 | allow_osc_retrim | 0 | RW | If set oscillator retrimming is allowed (register OSC_TRIM_VALUE_*) | | | | 2 | pulse_interrupt | 0 | RW | If set the INT pin has pulse behavior and shall not be cleared by the host, if cleared it is a level interrupt that shall be cleared by the host before reading the results | | | | 1:0 | reserved | 0 | RW | Reserved – keep at 0 | | | ## 8.5.17 SPAD\_MAP\_ID Register (Address 0x34) Figure 113: SPAD\_MAP\_ID Register | Addr: 0x34 SPAD_MAP_ID | | | .P_ID | | | |------------------------|-------------|---------|--------|----------|-----------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Des | cription | | | | | | Select S | SPAD map, which defines FoV | | | | | | Value | Description | | | spad_map_id | | | 0 | Reserved – do not use | | | | | | 1 | 3x3 normal mode 33°x32° FoV | | 3:0 | | 1 | RW | 2 | 3x3 macro 1 mode 33°x47° FoV off center (use macro 1 or macro 2 depending if camera is above or below TMF8820/21/28). | | | | | | 3 | 3x3 macro 2 mode 33°x47° FoV | | | | | | 4 | Only TMF8821: 4x4 macro 1 mode 33°x47° FoV (use macro 1 or macro 2 depending if camera is above or below TMF8821). | | Addr: 0x34 | | SPAD_MAP_ID | | | | | |------------|----------|-------------|--------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Des | cription | | | | | | | 5 | Only TMF8821: 4x4 macro 2 mode 33°x47° FoV | | | | | | | 6 | 3x3 wide mode 41°x52° FoV | | | | | | | 7 | Only TMF8821: 4x4 normal mode 41°x52° FoV | | | | | | | 8-9 | Reserved – do not use | | | | | | | 10 | Only TMF8821: 3x6 mode, 33°x60°<br>FoV | | | | | | | 11 | 3x3 mode 33°x32° FoV, checkerboard – disable 1 <sup>st</sup> , 3 <sup>rd</sup> , 5 <sup>th</sup> (use for high ambient light) | | | | | | | 12 | 3x3 mode 33°x32° FoV, inverted checkerboard – disable 2 <sup>nd</sup> , 4 <sup>th</sup> , 6 <sup>th</sup> (use for high ambient light) | | | | | | | 13 | Only TMF8821: 4x4 narrow mode 33°x42° FoV | | | | | | | 14 | User defined mode, single measurement mode using config_page_spad1 only | | | | | | | 15 | Only TMF8821: User defined mode, time multiplexed measurement mode using config_page_spad1 and 2 (note: in TMF8828 mode, this bit will be set when read but the user cannot define the SPAD mask) | | ## 8.5.18 ALG\_SETTING\_0 Register (Address 0x35) Figure 114: ALG\_SETTING\_0 Register | Addr: 0x35 ALG_SETTING | | TTING_0 | | | |------------------------|----------------------------|----------------|----|---------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default Access | | Bit Description | | 7 | logarithmic_co<br>nfidence | 0 | RW | This bit defines the confidence value encoding – see section 7.4.7 0 linear encoding 1 logarithmic encoding | | 6:3 | | 0 | RW | Reserved – keep at 0 | | 2 | distances | 1 | RW | If set do report distance results | | Addr: | 0x35 | ALG_SE | TTING_0 | | |-------|----------|---------|---------|----------------------| | Bit | Bit Name | Default | Access | Bit Description | | 1:0 | reserved | 0 | RW | Reserved – keep at 0 | Register 0x36-0x38 is reserved for future extensions – keep registers at default value of 0x00. ## 8.5.19 HIST\_DUMP Register (Address 0x39) Figure 115: **HIST\_DUMP** Register | Addr: 0 | Addr: 0x39 HIST_DUMP | | MP | | |---------|----------------------|---------|--------|-------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:1 | reserved | 0 | RW | Reserved – keep at 0 | | | | | | If set dump 24-bit raw histograms; do not set if int_persistence > 0 | | 0 | histogram | 0 | RW | See ams OSRAM device driver and/or application note TMF882X_Host_Driver_Communication_*.pdf for interpretation of this value. | #### 8.5.20 SPREAD\_SPECTRUM Register (Address 0x3A) Figure 116: SPREAD\_SPECTRUM Register | Addr: 0x3A S | | SPREAD | SPREAD_SPECTRUM | | | |--------------|----------------------------|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:3 | reserved | 0 | RW | Reserved – keep at 0 | | | 2:0 | spread_spectr<br>um_factor | 0 | RW | Spread spectrum configuration to avoid aliasing of far objects to closer distance – valid range 05. If set >0, this jitters the VCSEL pulses, which widens the frequency band for EMC emission. DO NOT SET HIGHER THAN 5. | | #### **Attention** Use the lastest firmware version to use the register spread\_spectrum\_factor. ## 8.5.21 I2C\_SLAVE\_ADDRESS Register (Address 0x3B) Figure 117: I2C\_SLAVE\_ADDRESS Register | Addr: 0x3B | | I2C_SLAVE_ADDRESS | | | | |------------|--------------------|-------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:1 | 7bit_slave_address | 0x41 | RW | I <sup>2</sup> C slave 7-bit address, a change requires the command CMD_I2C_SLAVE_ADDRESS to be executed; see register I2C_ADDR_CHANGE (0x3E) for conditions for this change | | | 0 | reserved | 0 | RW | Reserved – keep at 0 | | #### 8.5.22 OSC\_TRIM\_VALUE\_LSB Register (Address 0x3C) Figure 118: OSC\_TRIM\_VALUE\_LSB Register | Addr: 0x3C | | OSC_TRI | OSC_TRIM_VALUE_LSB | | | | |------------|---------------------|---------|--------------------|----------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | 7:0 | osc_trim_value[7:0] | 0 | RW | Oscillator trim value is a 9-bit signed value – bits 0-7 | | | ## 8.5.23 OSC\_TRIM\_VALUE\_MSB Register (Address 0x3D) Figure 119: OSC\_TRIM\_VALUE\_MSB Register | Addr: 0x3D | | OSC_TRIM | OSC_TRIM_VALUE_MSB | | | |------------|-------------------|----------|--------------------|-------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:1 | reserved | | | Reserved – keep at 0 | | | 0 | osc_trim_value[8] | 0 | RW | Oscillator trim value is a 9-bit signed value – bit 8 | | #### 8.5.24 I2C\_ADDR\_CHANGE Register (Address 0x3E) Figure 120: I2C ADDR CHANGE Register | Addr: 0x3E | | I2C_ADDR_CHANGE | | | |------------|-------------------|-----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 3:2 | gpio_change_mask | 0 | RW | See gpio_change_value | | 1:0 | gpio_change_value | 0 | RW | The command CMD_I2C_SLAVE_ADDRESS will only be executed if (gpio_data & gpio_change_mask) == (gpio_change_value & gpio_change_mask) Where gpio_data = [state of GPIO1, state of GPIO0] | Note: If the $I^2C$ address change shall be done in any case, set gpio\_change\_mask = 0 and gpio\_change\_value = 0. # 8.6 appid=0x03, cid\_rid=0x17/0x18 – User Defined SPAD Configuration Following registers are only available if appid=0x03 and cid\_rid=0x17/0x18 – SPAD configuration. For cid\_rid=0x17 these registers apply for non time multiplexed mode (3x3) or for the first measurement in time multiplexed mode (4x4 – only TMF8821). cid\_rid=0x18 is only available in TMF8821 and used for the second measurement in time multiplexed mode (4x4). Use ams OSRAM device driver to access these registers – they provide a high level interface to configure the SPAD mask. #### Information Please note that in TMF8828 mode, user defined SPAD masks are not available and any attempt to store a SPAD configuration will result in a warning in the status register. ## 8.6.1 SPAD\_ENABLE\_FIRST Register (Address 0x24) Figure 121: SPAD\_ENABLE\_FIRST Register | Addr: 0x24 | | SPAD_E | ST | | |------------|-------------------|---------|--------|---------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | spad_enable_first | 0 | RW | Start of SPAD enable mask | #### 8.6.2 SPAD\_ENABLE\_LAST Register (Address 0x41) Figure 122: SPAD\_ENABLE\_LAST Register | Addr: 0 | )x41 | SPAD_E | NABLE_LAS | ST | |---------|------------------|---------|-----------|---------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | spad_enable_last | 0 | RW | Start of SPAD enable mask | #### 8.6.3 SPAD\_TDC\_FIRST Register (Address 0x42) Figure 123: SPAD\_TDC\_FIRST Register | Addr: | 0x42 | SPAD_E | NABLE_FIR | ST | |-------|----------------|---------|-----------|------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | spad_tdc_first | 0 | RW | Start of SPAD to TDC channel select mask | ## 8.6.4 SPAD\_TDC\_LAST Register (Address 0x8C) Figure 124: SPAD\_TDC\_LAST Register | Addr: | 0x8C | SPAD_EN | NABLE_LAS | ST . | |-------|---------------|---------|-----------|------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | spad_tdc_last | 0 | RW | Start of SPAD to TDC channel select mask | ## 8.6.5 SPAD\_X\_OFFSET\_2 Register (Address 0x8D) Figure 125: SPAD\_X\_OFFSET\_2 Register | Addr: | 0x8D | SPAD_X | _OFFSET_ | 2 | |-------|------------|---------|----------|---------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | x_offset_2 | 0 | RW | Signed offset in x-direction in Q1 from the FoV center (Q1 = signed number multiplied by 2) | ## 8.6.6 SPAD\_Y\_OFFSET\_2 Register (Address 0x8E) Figure 126: SPAD\_Y\_OFFSET\_2 Register | Addr: | 0x8E | SPAD_Y | _OFFSET_ | 2 | |-------|------------|---------|----------|---------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | y_offset_2 | 0 | RW | Signed offset in y-direction in Q1 from the FoV center (Q1 = signed number multiplied by 2) | ## 8.6.7 SPAD\_X\_SIZE Register (Address 0x8F) Figure 127: SPAD\_X\_SIZE Register | Addr: | 0x8F | SPAD_X | _SIZE | | |-------|----------|---------|--------|-------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | x_size | 0 | RW | Size in full SPADs of the SPAD mask in x-direction (valid range is 118) | #### 8.6.8 SPAD\_Y\_SIZE Register (Address 0x90) Figure 128: SPAD\_Y\_SIZE Register | Addr: | 0x9 <b>0</b> | SPAD_Y_SIZE | | | |-------|--------------|-------------|--------|-------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | y_size | 0 | RW | Size in full SPADs of the SPAD mask in y-direction (valid range is 110) | ## 8.7 appid=0x03, cid\_rid=0x19 - Factory Calibration Following registers are only available if appid=0x03 and cid\_rid=0x19 - Factory calibration. #### 8.7.1 FACTORY\_CALIBRATION\_FIRST Register (Address 0x24) Figure 129: FACTORY\_CALIBRATION\_FIRST Register | Addr: 0x24 | | FACTORY_CALIBRATION_FIRST | | | |------------|---------------------------|---------------------------|--------|-----------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | factory_calibration_first | 0 | RW | Start of factory calibration data block | For crosstalk registers see Figure 48. #### 8.7.2 CALIBRATION\_STATUS\_FC Register (Address 0xDC) Figure 130: CALIBRATION\_STATUS\_FC Register | Addr: 0xDC | | CALIBR | CALIBRATION_STATUS_FC | | | |------------|----------------------|---------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | fc_status_during_cal | 0 | RW | Calibration status during factory calibration – copy of register 0x07 – 0x00 success, all other values are reporting an error during calibration | | #### 8.7.3 FACTORY\_CALIBRATION\_LAST Register (Address 0xDF) Figure 131: FACTORY\_CALIBRATION\_LAST Register | Addr: 0xDF | | FACTORY_CALIBRATION_LAST | | | | |------------|--------------------------|--------------------------|--------|---------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | factory_calibration_last | 0 | RW | End of factory calibration data block | | ## 8.8 appid=0x03, cid\_rid=0x81 - Raw Data Histograms Following registers are only available if appid=0x03 and cid\_rid=0x81 – Raw data histograms. ams OSRAM recommends to use ams OSRAM device driver how to use these registers. #### 8.8.1 SUBPACKET\_NUMBER Register (Address 0x24) Figure 132: SUBPACKET\_NUMBER Register | Addr: 0x24 | | SUBPACKET_NUMBER | | | |------------|------------------|------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | subpacket_number | 0 | RW | Subpacket number – see ams OSRAM device driver and/or application note TMF882X_Host_Driver_Communication_*.p df for interpretation of this value | #### 8.8.2 SUBPACKET\_PAYLOAD Register (Address 0x25) Figure 133: SUBPACKET\_PAYLOAD Register | Addr: 0 | Addr: 0x25 St | | SUBPACKET_PAYLOAD | | | | |---------|-------------------|---------|-------------------|-------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | 7:0 | subpacket_payload | 0x80 | RW | Size of payload – always 0x80 | | | ## 8.8.3 SUBPACKET\_CONFIG Register (Address 0x26) Figure 134: SUBPACKET\_CONFIG Register | Addr: 0x26 | | SUBPACKET_CONFIG | | | | |------------|------------------|------------------|--------|-----------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 0 | aubaakat aanfia | 0 | RW | 0 = No time multiplex or first timeslot of time multiplex | | | 0 | subpacket_config | 0 | IX V V | 1 = Second timeslot of time multiplex (only TMF8821) | | ## 8.8.4 SUBPACKET\_DATA0 Register (Address 0x27) Figure 135: SUBPACKET\_DATA0 Register | Addr: 0x27 | | SUBPACKET_DATA0 | | | | |------------|-----------------|-----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Bit Name | Default | Access | Bit Description | | | 7:0 | subpacket_data0 | 0 | RW | First data byte of this subpacket – see<br>ams OSRAM device driver and/or application<br>note<br>TMF882X_Host_Driver_Communication_*.pdf<br>for interpretation of this value | | #### 8.8.5 SUBPACKET\_DATA127 Register (Address 0xA6) Figure 136: SUBPACKET\_DATA127 Register | Addr: | Addr: 0xA6 | | SUBPACKET_DATA127 | | | | |-------|-------------------|---------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Bit Name | Default | Access | Bit Description | | | | 7:0 | subpacket_data127 | 0 | RW | Last data byte of this subpacket – see<br>ams OSRAM device driver and/or application<br>note<br>TMF882X_Host_Driver_Communication_*.pdf<br>for interpretation of this value | | | ## 8.9 appid=0x80 – Bootloader Registers Following registers are only available if appid=0x80 (Bootloader). ams OSRAM recommends to use ams OSRAM device driver to operate the bootloader. #### 8.9.1 BL\_CMD\_STAT (Address 0x08) Figure 137: **BL\_CMD\_STAT** Register | Addı | r: 0x08 | BL_CMD_STAT | | | | |------|---------------|-------------|--------|--------|------------------------------------------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit De | scription | | | bl_cmd_stat ( | | RW | Bootlo | Bootloader Command – see section 8.9.5 ader Commands<br>Bootloader Status: | | | | | | 0x00 | STAT_READY - the last command executed successfully | | 7:0 | | 0 | | 0x01 | STAT_ERR_SIZE - the last command had a size mismatch | | 7.0 | | | | 0x02 | STAT_ERR_CSUM - the last command had a faulty checksum or was unknown | | | | | | 0x03 | STAT_ERR_RANGE - the last command tried to access RAM out of range | | | | | | 0x04 | STAT_ERR_MORE - the last command caused an error and there is more information in the response | #### 8.9.2 BL\_SIZE (Address 0x09) Figure 138: **BL\_SIZE** Register | Addr: | 0x09 | BL_SIZE | | | |-------|----------|---------|--------|--------------------| | Bit | Bit Name | Default | Access | Bit Description | | 6:0 | bl_size | 0 | RW | Data size in bytes | #### 8.9.3 BL\_DATA (Address 0x0A-0x8A) Figure 139: **BL\_DATA** Register | Addr: | 0x0A-0x8A | BL_DAT | A | | |-------|------------------------|---------|--------|----------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | bl_data0<br>bl_data127 | 0 | RW | Up to 128 data bytes for bootloader commands | ## 8.9.4 BL\_CSUM (Address after bl\_data\*) The actual I<sup>2</sup>C address of BL\_SUM depends on the length of the payload (bl\_data0-bl\_data127); BL\_SUM always is after the last data byte. Note: If there is no databyte, BL\_SUM address is 0x0A. Figure 140: **BL\_CSUM** Register | Addr: | After bl_data* | BL_CSU | М | | |-------|----------------|---------|--------|--------------------------------------------------------------| | Bit | Bit Name | Default | Access | Bit Description | | 7:0 | bl_csum | 0 | RW | Checksum for Sum(Command + Data Size + Data itself) XOR 0xFF | #### 8.9.5 Bootloader Commands The following commands (bl\_cmd\_stat) are supported by the bootloader: Figure 141: **Bootloader Commands** | Command | Value | Meaning | |----------------|-------|--------------------------------------------------------------------| | RAMREMAP_RESET | 0x11 | Remap RAM to Address 0 and Reset | | DOWNLOAD_INIT | 0x14 | Initialize for RAM download from host to TMF8820/21/28 | | RAM_BIST | 0x2A | Build in self test of RAM (pattern test) | | I2C_BIST | 0x2C | Build in self test of I <sup>2</sup> C RAM (pattern test) | | W_RAM | 0x41 | Write RAM Region (Plain = not encoded into e.g. Intel Hex Records) | | Command | Value | Meaning | |----------|-------|---------------------------------------------------| | ADDR_RAM | 0x43 | Set the read/write RAM pointer to a given address | #### RAMREMAP\_RESET = Execute Program Downloaded to RAM This command remaps the RAM to address 0 and performs a System reset. Before executing this command, set powerup\_select = 2. Command is performed immediately without any delay. After this the application that is located in RAM will be running. If there is no valid application you will need to do a HW reset (toggle enable pin or power cycle). Figure 142: RAMREMAP\_RESET | Address | Value | Meaning | |-------------|-------|--------------------------| | BL_CMD_STAT | 0x11 | REMAP RAM to 0 and RESET | | BL_SIZE | 0 | No parameters | | BL_CSUM | 0xEE | | #### DOWNLOAD\_INIT This command is used to initialize the download HW for secure devices. Figure 143: DOWNLOAD INIT | Address | Value | Meaning | |-------------|-------|---------------------------------------------------------------| | BL_CMD_STAT | 0x14 | Initialize the HW for download from host to TMF8820/21/28 RAM | | BL_SIZE | 1 | | | BL_DATA0 | 00xFF | Seed | | BL_CSUM | 00xFF | | #### **RAM\_BIST** This command is to perform a RAM pattern test on the main RAM region. Figure 144: RAM\_BIST | Address | Value | Meaning | |-------------|-------|----------------------------------| | BL_CMD_STAT | 0x2A | Start pattern testing on the RAM | | BL_SIZE | 0 | | | BL_CSUM | 0xD5 | | BL\_CMD\_STAT will report pass / fail of the test. #### I2C\_BIST This command is to perform a RAM pattern test on the I<sup>2</sup>C RAM region. #### Figure 145: I2C\_BIST | Address | Value | Meaning | |-------------|-------|---------------------------------------------------| | BL_CMD_STAT | 0x2C | Start pattern testing on the I <sup>2</sup> C RAM | | BL_SIZE | 0 | | | BL_CSUM | 0xD3 | | During execution of this test cpu\_ready=0. Wait until cpu\_ready=1 and then BL\_CMD\_STAT will report pass / fail of the test. #### W\_RAM This command writes the given data to a defined RAM region. Note that the RAM pointer has first to be set by the command ADDR\_RAM. After the command is successfully executed, the RAM pointer will point to the first byte after the written region. #### Figure 146: W\_RAM | Address | Value | Meaning | |-------------|-------|------------------------------------| | BL_CMD_STAT | 0x41 | Write to main RAM | | BL_SIZE | 00x80 | Number of bytes to be written | | BL_DATA0 | 00xFF | 1 <sup>st</sup> byte to be written | | BL_DATA1 | 00xFF | 2 <sup>nd</sup> byte to be written | | | | | | Address | Value | Meaning | |------------|-------|--------------------------------------------------------------| | BL_DATA127 | 00xFF | 128 <sup>th</sup> byte to be written (only if size was 0x80) | | BL_CSUM | 00xFF | The CSUM comes immediately after the data. | #### ADDR\_RAM This command is to specify the RAM pointer location for the next R\_RAM or W\_RAM command. Figure 147: ADDR\_RAM | Address | Value | Meaning | |-------------|-------|----------------------------------------------------| | BL_CMD_STAT | 0x43 | Specify the address of the next RAM read or write. | | BL_SIZE | 2 | | | BL_DATA0 | 00xFF | LSB of address in RAM | | BL_DATA1 | 00xFF | MSB of address in RAM | | BL_CSUM | 00xFF | | ## 9 Application Information #### 9.1 Schematic The TMF8820/21/28 needs only 3 small 0402 external capacitors for operation: Figure 148: TMF8820/21/28 Application Schematic The SYNC signal connected to GPIO1 can be used to immediately interrupt the TMF8820/21/28 VCSEL operation if the high power illuminator is operating or to sync to a camera operation. Ensure that SYNC does not exceed the VDD supply of TMF8820/21/28 as otherwise an internal protection diode will start conducting. On SYNC assertion, the VCSEL is immediately switched off (typically after 10 $\mu$ s), on SYNC de-assertion the VCSEL operation is resumed. GPIO0 can be used as a general GPIO output signal. The signals INT/SDA/SCL need an external pull-up resistor to the VIO supply (typically 1.8 V). ## 9.1.1 Operating Several TMF8820/21/28 Devices on a Single I<sup>2</sup>C Bus Several TMF8820/21/28 devices can share a single I<sup>2</sup>C bus if there are dedicated enable (EN) connections to each of these devices. Figure 149: Sharing a Single I<sup>2</sup>C Bus for Operating Several TMF8820/21/28s The procedure to initialize the devices to different I<sup>2</sup>C addresses is as follows: - 1. Set EN1=0, EN2=0, EN3=0 (reset all devices) - 2. Set EN1=1 - 3. Download firmware to first TMF8820/21/28 - 4. Reprogram I<sup>2</sup>C address for first TMF8820/21/28 using cmd\_stat = CMD\_I2C\_SLAVE\_ADDRESS where 7bit\_slave\_address(0x3B) = I<sup>2</sup>C address for first TMF8820/21/28; set gpio\_change\_mask = 0 and gpio\_change\_value = 0. - 5. Set EN2=1 - 6. Download firmware to second TMF8820/21/28 - 7. Reprogram I<sup>2</sup>C address for second TMF8820/21/28 using cmd\_stat = CMD\_I2C\_SLAVE\_ADDRESS where 7bit\_slave\_address(0x3B) = I<sup>2</sup>C address for second TMF8820/21/28; set gpio\_change\_mask = 0 and gpio\_change\_value = 0. - 8. Set EN3=1 - 9. Download firmware to third TMF8820/21/28 - 10. Reprogram I<sup>2</sup>C address for third TMF8820/21/28 using cmd\_stat = CMD\_I2C\_SLAVE\_ADDRESS where 7bit\_slave\_address(0x3B) = I<sup>2</sup>C address for third TMF8820/21/28; set gpio\_change\_mask = 0 and gpio\_change\_value = 0. - 11. If there are further devices, repeat last three steps accordingly. ## 9.2 PCB Layout Figure 150: PCB Layout Recommendation ## 9.3 External Components The TMF8820/21/28 only need three small 0402 sized capacitors for operation. Use GRM155R70J104KA01 (0402 X7R 0.1 $\mu$ F 6.3 V) or capacitors with same or better performance for CVDDC, CVDD and CVDDV. Add pull-up resistors (e.g. 10 k $\Omega$ ) on pins SCL, SDA and INT. ## 9.4 PCB Pad Layout Figure 151: PCB Pad Layout - (1) All linear dimensions are in millimeters. - (2) Dimension tolerances are 0.05 mm unless otherwise noted. - (3) This drawing is subject to change without notice. Use the PCB pad layout as a recommendation only. The actual pad layout shall be optimized for the customer production line. ## 9.5 Software Drivers ams OSRAM recommends to use one of the available software drivers to operate the TMF8820/21/28. The drivers are available from the **ams** website: - For TMF8820 see https://ams.com/tmf8820 - For TMF8821 see https://ams.com/tmf8821 - For TMF8828 see https://ams.com/tmf8828 There are following drivers available: Figure 152: Available Drivers | Туре | File | Explanation | |-------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Linux | TMF882x_Driver_Linux_v*.zip and TMF882x_Driver_Linux_Source_v*.zip | Use for any Linux system (e.g. Android) where the driver is running on the application processor. This is the driver running on TMF882x evaluation kit. | | SDK | TMF882x_Driver_SDK_Source_v*.zip | Driver and several examples for using of the TMF8820/21/28 bundled inside a software development kit – the driver works out of the box using the tmf882x-mcu-shield-evm boards and an NXP LPC55S69-EVK, but should make porting to other hardware platforms easier. | | MCU | TMF882x_Driver_MCU_Source_v*.zip | MCU driver – sometimes referenced as bare metal driver – the hardware functions for executing the I <sup>2</sup> C routines can be easily replaced to simply port this driver to systems without operating system or systems not running Linux | ## 10 Package Drawings & Markings Figure 153: OLGA12 Package Outline Drawing - (1) All dimensions are in millimeters. Angles in degrees. - (2) Dimensioning and tolerancing conform to ASME Y14.5M-1994. - (3) n is the total number of terminals. - (4) This package contains no lead (Pb). - (5) This drawing is subject to change without notice. - (6) 8-digit tracecode only on bottom side of the package. ## 11 Tape & Reel Information Figure 154: Tape and Reel Drawing - (1) All linear dimensions are in millimeters. Dimension tolerance is $\pm$ 0.10 mm unless otherwise noted. - (2) The dimensions on this drawing are for illustrative purposes only. Dimensions of an actual carrier may vary slightly. - (3) Symbols on drawing A0, B0, and K0 are defined in ANSI EIA Standard 481-B 2001. - (4) There are two reel sizes available (see section Ordering Information)i) 7" reels: Each reel is 7 inch in diameter and contains 500 parts. - ii) 13" reels: Each reel is 13 inch in diameter and contains 4000 parts. - (5) ams OSRAM packaging tape and reel conform to the requirements of EIA Standard 481-B. - (6) In accordance with EIA standard, device pin 1 is located next to sprocket holes in the tape. - (7) This drawing is subject to change without notice. ## 12 Soldering & Storage Information ## 12.1 Soldering Information The package has been tested and has demonstrated an ability to be reflow soldered to a PCB substrate. The solder reflow profile describes the expected maximum heat exposure of components during the solder reflow process of product on a PCB. Temperature is measured on top of component. The components shall be limited to a maximum of three passes through this solder reflow profile. Figure 155: Solder Reflow Profile Graph Figure 156: Solder Reflow Profile | Parameter | Reference | Device | |--------------------------------------------------------|-------------------|----------------| | Average temperature gradient in preheating | | 2.5 °C/s | | Soak time | t <sub>soak</sub> | 2 to 3 minutes | | Time above 217 °C (T <sub>1</sub> ) | t <sub>1</sub> | Max 60 s | | Time above 230 °C (T <sub>2</sub> ) | t <sub>2</sub> | Max 50 s | | Time above T <sub>peak</sub> – 10 °C (T <sub>3</sub> ) | t <sub>3</sub> | Max 10 s | | Peak temperature in reflow | T <sub>peak</sub> | 260 °C | | Temperature gradient in cooling | | Max −5 °C/s | ## 12.2 Storage Information #### 12.2.1 Moisture Sensitivity Optical characteristics of the device can be adversely affected during the soldering process by the release and vaporization of moisture that has been previously absorbed into the package. To ensure the package contains the smallest amount of absorbed moisture possible, each device is baked prior to being dry packed for shipping. Devices are dry packed in a sealed aluminized envelope called a moisture-barrier bag with silica gel to protect them from ambient moisture during shipping, handling, and storage before use. #### **Shelf Life** The calculated shelf life of the device in an unopened moisture barrier bag is 12 months from the date code on the bag when stored under the following conditions: - Shelf Life: 12 months - Ambient Temperature: <40 °C</li> - Relative Humidity: <90 %</li> Rebaking of the devices will be required if the devices exceed the 12 month shelf life or the Humidity Indicator Card shows that the devices were exposed to conditions beyond the allowable moisture region. #### Floor Life The module has been assigned a moisture sensitivity level of MSL 3. As a result, the floor life of devices removed from the moisture barrier bag is 168 hours from the time the bag was opened, provided that the devices are stored under the following conditions: Floor Life: 168 hours Ambient Temperature: <30 °C</li> Relative Humidity: <60 %</li> If the floor life or the temperature/humidity conditions have been exceeded, the devices must be rebaked prior to solder reflow or dry packing. #### **Rebaking Instructions** When the shelf life or floor life limits have been exceeded, rebake at 50 °C for 12 hours. ## 13 Laser Eye Safety The TMF8820/21/28 is designed to meet the Class 1 laser safety limits including single faults in compliance with IEC / EN 60825-1:2014. This applies to the stand-alone device and the included software supplied by ams OSRAM. In an end application system environment, the system may need to be tested to ensure it remains compliant. The system must not include any additional lens to concentrate the laser light or parameters set outside of the recommended operating conditions. Use outside of the recommended condition or any physical modification to the module during development could result in hazardous levels of radiation exposure. Figure 157: Laser Eye Safety Certificate Complies with 21 CFR 1040.10 and 1040.11 except for conformance with IEC 60825-1 Ed. 3., as described in Laser Notice No. 56, dated May 8, 2019. #### **CAUTION** Use of controls or adjustments or performance of procedures other than those specified herein may result in hazardous radiation exposure. Example: Adding a converging lens on top of the TMF8820/21/28 ## 14 Revision Information | Document Status | Product Status | Definition | |-----------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Product Preview | Pre-Development | Information in this datasheet is based on product ideas in the planning phase of development. All specifications are design goals without any warranty and are subject to change without notice | | Preliminary Datasheet | Pre-Production | Information in this datasheet is based on products in the design, validation or qualification phase of development. The performance and parameters shown in this document are preliminary without any warranty and are subject to change without notice | | Datasheet | Production | Information in this datasheet is based on products in ramp-up to full production or full production which conform to specifications in accordance with the terms of ams-OSRAM AG standard warranty as given in the General Terms of Trade | | Datasheet<br>(discontinued) | Discontinued | Information in this datasheet is based on products which conform to specifications in accordance with the terms of ams-OSRAM AG standard warranty as given in the General Terms of Trade, but these products have been superseded and should not be used for new designs | | Changes from previous version to current revision v5-00 | Page | |--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------| | Used 1 MHz for firmware download | 11 | | Minor updates with additional information (ranging flow in time multiplex, reference for latest firmware, timings in 8x8 mode, customized SPAD map creation) | 19, 21, 22, 25 | | Added short range high accuracy mode | 30 | | Removed live_gpio register | 38 | | Added active_range register | 38, 53 | | Added spread_spectrum | 40, 48, 74 | | Clarified timing for readout of register appid, minor, patch and build | 42, 46 | | Explained bl_cmd_stat error codes | 82 | | Update software drivers and added SDK | 91 | - Page and figure numbers for the previous version may differ from page and figure numbers in the current revision. - Correction of typographical errors is not explicitly mentioned. #### **Legal Information** 15 #### Copyrights & Disclaimer Copyright ams-OSRAM AG, Tobelbader Strasse 30, 8141 Premstaetten, Austria-Europe. Trademarks Registered. All rights reserved. The material herein may not be reproduced, adapted, merged, translated, stored, or used without the prior written consent of the copyright owner. Devices sold by ams-OSRAM AG are covered by the warranty and patent indemnification provisions appearing in its General Terms of Trade. ams-OSRAM AG makes no warranty, express, statutory, implied, or by description regarding the information set forth herein. ams-OSRAM AG reserves the right to change specifications and prices at any time and without notice. Therefore, prior to designing this product into a system, it is necessary to check with ams-OSRAM AG for current information. This product is intended for use in commercial applications. Applications requiring extended temperature range, unusual environmental requirements, or high reliability applications, such as military, medical life-support or life-sustaining equipment are specifically not recommended without additional processing by ams-OSRAM AG for each application. This product is provided by ams-OSRAM AG "AS IS" and any express or implied warranties, including, but not limited to the implied warranties of merchantability and fitness for a particular purpose are disclaimed. ams-OSRAM AG shall not be liable to recipient or any third party for any damages, including but not limited to personal injury, property damage, loss of profits, loss of use, interruption of business or indirect, special, incidental or consequential damages, of any kind, in connection with or arising out of the furnishing, performance or use of the technical data herein. No obligation or liability to recipient or any third party shall arise or flow out of ams-OSRAM AG rendering of technical or other services. #### **RoHS Compliant & ams Green Statement** RoHS Compliant: The term RoHS compliant means that ams-OSRAM AG products fully comply with current RoHS directives. Our semiconductor products do not contain any chemicals for all 6 substance categories plus additional 4 substance categories (per amendment EU 2015/863), including the requirement that lead not exceed 0.1% by weight in homogeneous materials. Where designed to be soldered at high temperatures, RoHS compliant products are suitable for use in specified lead-free ams Green (RoHS compliant and no Sb/Br/CI): ams Green defines that in addition to RoHS compliance, our products are free of Bromine (Br) and Antimony (Sb) based flame retardants (Br or Sb do not exceed 0.1% by weight in homogeneous material) and do not contain Chlorine (Cl not exceed 0.1% by weight in homogeneous material). Important Information: The information provided in this statement represents ams-OSRAM AG knowledge and belief as of the date that it is provided. ams-OSRAM AG bases its knowledge and belief on information provided by third parties, and makes no representation or warranty as to the accuracy of such information. Efforts are underway to better integrate information from third parties. ams-OSRAM AG has taken and continues to take reasonable steps to provide representative and accurate information but may not have conducted destructive testing or chemical analysis on incoming materials and chemicals. ams-OSRAM AG and ams-OSRAM AG suppliers consider certain information to be proprietary, and thus CAS numbers and other limited information may not be available for release. #### Headquarters ams-OSRAM AG Tobelbader Strasse 30 8141 Premstaetten Austria, Europe Tel: +43 (0) 3136 500 0 Please visit our website at www.ams.com Buy our products or get free samples online at www.ams.com/Products Technical Support is available at www.ams.com/Technical-Support Provide feedback about this document at www.ams.com/Document-Feedback For sales offices, distributors and representatives go to www.ams.com/Contact For further information and requests, e-mail us at ams\_sales@ams.com