1414 lines
113 KiB
C++
1414 lines
113 KiB
C++
|
/******************************************************************************
|
||
|
vl53l1x.hpp
|
||
|
Based on the code in https://github.com/pololu/vl53l1x-arduino
|
||
|
Modified by https://github.com/simon3270/driver-vl53l1x
|
||
|
|
||
|
This code is released under the BSD 3-clause license accompanying this code.
|
||
|
Please review the LICENSE file included with this example.
|
||
|
Distributed as-is; no warranty is given.
|
||
|
******************************************************************************/
|
||
|
|
||
|
#pragma once
|
||
|
|
||
|
#include "hardware/i2c.h"
|
||
|
#include "hardware/gpio.h"
|
||
|
|
||
|
#include <stdio.h>
|
||
|
#include "pico/stdlib.h"
|
||
|
|
||
|
namespace pimoroni {
|
||
|
|
||
|
class VL53L1X {
|
||
|
|
||
|
i2c_inst_t *i2c = i2c0;
|
||
|
|
||
|
int8_t address = 0x29;
|
||
|
int8_t sda = 20;
|
||
|
int8_t scl = 21;
|
||
|
int8_t interrupt = 22;
|
||
|
|
||
|
// register addresses from API vl53l1x_register_map.h
|
||
|
enum regAddr : uint16_t
|
||
|
{
|
||
|
SOFT_RESET = 0x0000,
|
||
|
I2C_SLAVE__DEVICE_ADDRESS = 0x0001,
|
||
|
ANA_CONFIG__VHV_REF_SEL_VDDPIX = 0x0002,
|
||
|
ANA_CONFIG__VHV_REF_SEL_VQUENCH = 0x0003,
|
||
|
ANA_CONFIG__REG_AVDD1V2_SEL = 0x0004,
|
||
|
ANA_CONFIG__FAST_OSC__TRIM = 0x0005,
|
||
|
OSC_MEASURED__FAST_OSC__FREQUENCY = 0x0006,
|
||
|
OSC_MEASURED__FAST_OSC__FREQUENCY_HI = 0x0006,
|
||
|
OSC_MEASURED__FAST_OSC__FREQUENCY_LO = 0x0007,
|
||
|
VHV_CONFIG__TIMEOUT_MACROP_LOOP_BOUND = 0x0008,
|
||
|
VHV_CONFIG__COUNT_THRESH = 0x0009,
|
||
|
VHV_CONFIG__OFFSET = 0x000A,
|
||
|
VHV_CONFIG__INIT = 0x000B,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_REF_0 = 0x000D,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_REF_1 = 0x000E,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_REF_2 = 0x000F,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_REF_3 = 0x0010,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_REF_4 = 0x0011,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_REF_5 = 0x0012,
|
||
|
GLOBAL_CONFIG__REF_EN_START_SELECT = 0x0013,
|
||
|
REF_SPAD_MAN__NUM_REQUESTED_REF_SPADS = 0x0014,
|
||
|
REF_SPAD_MAN__REF_LOCATION = 0x0015,
|
||
|
ALGO__CROSSTALK_COMPENSATION_PLANE_OFFSET_KCPS = 0x0016,
|
||
|
ALGO__CROSSTALK_COMPENSATION_PLANE_OFFSET_KCPS_HI = 0x0016,
|
||
|
ALGO__CROSSTALK_COMPENSATION_PLANE_OFFSET_KCPS_LO = 0x0017,
|
||
|
ALGO__CROSSTALK_COMPENSATION_X_PLANE_GRADIENT_KCPS = 0x0018,
|
||
|
ALGO__CROSSTALK_COMPENSATION_X_PLANE_GRADIENT_KCPS_HI = 0x0018,
|
||
|
ALGO__CROSSTALK_COMPENSATION_X_PLANE_GRADIENT_KCPS_LO = 0x0019,
|
||
|
ALGO__CROSSTALK_COMPENSATION_Y_PLANE_GRADIENT_KCPS = 0x001A,
|
||
|
ALGO__CROSSTALK_COMPENSATION_Y_PLANE_GRADIENT_KCPS_HI = 0x001A,
|
||
|
ALGO__CROSSTALK_COMPENSATION_Y_PLANE_GRADIENT_KCPS_LO = 0x001B,
|
||
|
REF_SPAD_CHAR__TOTAL_RATE_TARGET_MCPS = 0x001C,
|
||
|
REF_SPAD_CHAR__TOTAL_RATE_TARGET_MCPS_HI = 0x001C,
|
||
|
REF_SPAD_CHAR__TOTAL_RATE_TARGET_MCPS_LO = 0x001D,
|
||
|
ALGO__PART_TO_PART_RANGE_OFFSET_MM = 0x001E,
|
||
|
ALGO__PART_TO_PART_RANGE_OFFSET_MM_HI = 0x001E,
|
||
|
ALGO__PART_TO_PART_RANGE_OFFSET_MM_LO = 0x001F,
|
||
|
MM_CONFIG__INNER_OFFSET_MM = 0x0020,
|
||
|
MM_CONFIG__INNER_OFFSET_MM_HI = 0x0020,
|
||
|
MM_CONFIG__INNER_OFFSET_MM_LO = 0x0021,
|
||
|
MM_CONFIG__OUTER_OFFSET_MM = 0x0022,
|
||
|
MM_CONFIG__OUTER_OFFSET_MM_HI = 0x0022,
|
||
|
MM_CONFIG__OUTER_OFFSET_MM_LO = 0x0023,
|
||
|
DSS_CONFIG__TARGET_TOTAL_RATE_MCPS = 0x0024,
|
||
|
DSS_CONFIG__TARGET_TOTAL_RATE_MCPS_HI = 0x0024,
|
||
|
DSS_CONFIG__TARGET_TOTAL_RATE_MCPS_LO = 0x0025,
|
||
|
DEBUG__CTRL = 0x0026,
|
||
|
TEST_MODE__CTRL = 0x0027,
|
||
|
CLK_GATING__CTRL = 0x0028,
|
||
|
NVM_BIST__CTRL = 0x0029,
|
||
|
NVM_BIST__NUM_NVM_WORDS = 0x002A,
|
||
|
NVM_BIST__START_ADDRESS = 0x002B,
|
||
|
HOST_IF__STATUS = 0x002C,
|
||
|
PAD_I2C_HV__CONFIG = 0x002D,
|
||
|
PAD_I2C_HV__EXTSUP_CONFIG = 0x002E,
|
||
|
GPIO_HV_PAD__CTRL = 0x002F,
|
||
|
GPIO_HV_MUX__CTRL = 0x0030,
|
||
|
GPIO__TIO_HV_STATUS = 0x0031,
|
||
|
GPIO__FIO_HV_STATUS = 0x0032,
|
||
|
ANA_CONFIG__SPAD_SEL_PSWIDTH = 0x0033,
|
||
|
ANA_CONFIG__VCSEL_PULSE_WIDTH_OFFSET = 0x0034,
|
||
|
ANA_CONFIG__FAST_OSC__CONFIG_CTRL = 0x0035,
|
||
|
SIGMA_ESTIMATOR__EFFECTIVE_PULSE_WIDTH_NS = 0x0036,
|
||
|
SIGMA_ESTIMATOR__EFFECTIVE_AMBIENT_WIDTH_NS = 0x0037,
|
||
|
SIGMA_ESTIMATOR__SIGMA_REF_MM = 0x0038,
|
||
|
ALGO__CROSSTALK_COMPENSATION_VALID_HEIGHT_MM = 0x0039,
|
||
|
SPARE_HOST_CONFIG__STATIC_CONFIG_SPARE_0 = 0x003A,
|
||
|
SPARE_HOST_CONFIG__STATIC_CONFIG_SPARE_1 = 0x003B,
|
||
|
ALGO__RANGE_IGNORE_THRESHOLD_MCPS = 0x003C,
|
||
|
ALGO__RANGE_IGNORE_THRESHOLD_MCPS_HI = 0x003C,
|
||
|
ALGO__RANGE_IGNORE_THRESHOLD_MCPS_LO = 0x003D,
|
||
|
ALGO__RANGE_IGNORE_VALID_HEIGHT_MM = 0x003E,
|
||
|
ALGO__RANGE_MIN_CLIP = 0x003F,
|
||
|
ALGO__CONSISTENCY_CHECK__TOLERANCE = 0x0040,
|
||
|
SPARE_HOST_CONFIG__STATIC_CONFIG_SPARE_2 = 0x0041,
|
||
|
SD_CONFIG__RESET_STAGES_MSB = 0x0042,
|
||
|
SD_CONFIG__RESET_STAGES_LSB = 0x0043,
|
||
|
GPH_CONFIG__STREAM_COUNT_UPDATE_VALUE = 0x0044,
|
||
|
GLOBAL_CONFIG__STREAM_DIVIDER = 0x0045,
|
||
|
SYSTEM__INTERRUPT_CONFIG_GPIO = 0x0046,
|
||
|
CAL_CONFIG__VCSEL_START = 0x0047,
|
||
|
CAL_CONFIG__REPEAT_RATE = 0x0048,
|
||
|
CAL_CONFIG__REPEAT_RATE_HI = 0x0048,
|
||
|
CAL_CONFIG__REPEAT_RATE_LO = 0x0049,
|
||
|
GLOBAL_CONFIG__VCSEL_WIDTH = 0x004A,
|
||
|
PHASECAL_CONFIG__TIMEOUT_MACROP = 0x004B,
|
||
|
PHASECAL_CONFIG__TARGET = 0x004C,
|
||
|
PHASECAL_CONFIG__OVERRIDE = 0x004D,
|
||
|
DSS_CONFIG__ROI_MODE_CONTROL = 0x004F,
|
||
|
SYSTEM__THRESH_RATE_HIGH = 0x0050,
|
||
|
SYSTEM__THRESH_RATE_HIGH_HI = 0x0050,
|
||
|
SYSTEM__THRESH_RATE_HIGH_LO = 0x0051,
|
||
|
SYSTEM__THRESH_RATE_LOW = 0x0052,
|
||
|
SYSTEM__THRESH_RATE_LOW_HI = 0x0052,
|
||
|
SYSTEM__THRESH_RATE_LOW_LO = 0x0053,
|
||
|
DSS_CONFIG__MANUAL_EFFECTIVE_SPADS_SELECT = 0x0054,
|
||
|
DSS_CONFIG__MANUAL_EFFECTIVE_SPADS_SELECT_HI = 0x0054,
|
||
|
DSS_CONFIG__MANUAL_EFFECTIVE_SPADS_SELECT_LO = 0x0055,
|
||
|
DSS_CONFIG__MANUAL_BLOCK_SELECT = 0x0056,
|
||
|
DSS_CONFIG__APERTURE_ATTENUATION = 0x0057,
|
||
|
DSS_CONFIG__MAX_SPADS_LIMIT = 0x0058,
|
||
|
DSS_CONFIG__MIN_SPADS_LIMIT = 0x0059,
|
||
|
MM_CONFIG__TIMEOUT_MACROP_A = 0x005A, // added by Pololu for 16-bit accesses
|
||
|
MM_CONFIG__TIMEOUT_MACROP_A_HI = 0x005A,
|
||
|
MM_CONFIG__TIMEOUT_MACROP_A_LO = 0x005B,
|
||
|
MM_CONFIG__TIMEOUT_MACROP_B = 0x005C, // added by Pololu for 16-bit accesses
|
||
|
MM_CONFIG__TIMEOUT_MACROP_B_HI = 0x005C,
|
||
|
MM_CONFIG__TIMEOUT_MACROP_B_LO = 0x005D,
|
||
|
RANGE_CONFIG__TIMEOUT_MACROP_A = 0x005E, // added by Pololu for 16-bit accesses
|
||
|
RANGE_CONFIG__TIMEOUT_MACROP_A_HI = 0x005E,
|
||
|
RANGE_CONFIG__TIMEOUT_MACROP_A_LO = 0x005F,
|
||
|
RANGE_CONFIG__VCSEL_PERIOD_A = 0x0060,
|
||
|
RANGE_CONFIG__TIMEOUT_MACROP_B = 0x0061, // added by Pololu for 16-bit accesses
|
||
|
RANGE_CONFIG__TIMEOUT_MACROP_B_HI = 0x0061,
|
||
|
RANGE_CONFIG__TIMEOUT_MACROP_B_LO = 0x0062,
|
||
|
RANGE_CONFIG__VCSEL_PERIOD_B = 0x0063,
|
||
|
RANGE_CONFIG__SIGMA_THRESH = 0x0064,
|
||
|
RANGE_CONFIG__SIGMA_THRESH_HI = 0x0064,
|
||
|
RANGE_CONFIG__SIGMA_THRESH_LO = 0x0065,
|
||
|
RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS = 0x0066,
|
||
|
RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS_HI = 0x0066,
|
||
|
RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS_LO = 0x0067,
|
||
|
RANGE_CONFIG__VALID_PHASE_LOW = 0x0068,
|
||
|
RANGE_CONFIG__VALID_PHASE_HIGH = 0x0069,
|
||
|
SYSTEM__INTERMEASUREMENT_PERIOD = 0x006C,
|
||
|
SYSTEM__INTERMEASUREMENT_PERIOD_3 = 0x006C,
|
||
|
SYSTEM__INTERMEASUREMENT_PERIOD_2 = 0x006D,
|
||
|
SYSTEM__INTERMEASUREMENT_PERIOD_1 = 0x006E,
|
||
|
SYSTEM__INTERMEASUREMENT_PERIOD_0 = 0x006F,
|
||
|
SYSTEM__FRACTIONAL_ENABLE = 0x0070,
|
||
|
SYSTEM__GROUPED_PARAMETER_HOLD_0 = 0x0071,
|
||
|
SYSTEM__THRESH_HIGH = 0x0072,
|
||
|
SYSTEM__THRESH_HIGH_HI = 0x0072,
|
||
|
SYSTEM__THRESH_HIGH_LO = 0x0073,
|
||
|
SYSTEM__THRESH_LOW = 0x0074,
|
||
|
SYSTEM__THRESH_LOW_HI = 0x0074,
|
||
|
SYSTEM__THRESH_LOW_LO = 0x0075,
|
||
|
SYSTEM__ENABLE_XTALK_PER_QUADRANT = 0x0076,
|
||
|
SYSTEM__SEED_CONFIG = 0x0077,
|
||
|
SD_CONFIG__WOI_SD0 = 0x0078,
|
||
|
SD_CONFIG__WOI_SD1 = 0x0079,
|
||
|
SD_CONFIG__INITIAL_PHASE_SD0 = 0x007A,
|
||
|
SD_CONFIG__INITIAL_PHASE_SD1 = 0x007B,
|
||
|
SYSTEM__GROUPED_PARAMETER_HOLD_1 = 0x007C,
|
||
|
SD_CONFIG__FIRST_ORDER_SELECT = 0x007D,
|
||
|
SD_CONFIG__QUANTIFIER = 0x007E,
|
||
|
ROI_CONFIG__USER_ROI_CENTRE_SPAD = 0x007F,
|
||
|
ROI_CONFIG__USER_ROI_REQUESTED_GLOBAL_XY_SIZE = 0x0080,
|
||
|
SYSTEM__SEQUENCE_CONFIG = 0x0081,
|
||
|
SYSTEM__GROUPED_PARAMETER_HOLD = 0x0082,
|
||
|
POWER_MANAGEMENT__GO1_POWER_FORCE = 0x0083,
|
||
|
SYSTEM__STREAM_COUNT_CTRL = 0x0084,
|
||
|
FIRMWARE__ENABLE = 0x0085,
|
||
|
SYSTEM__INTERRUPT_CLEAR = 0x0086,
|
||
|
SYSTEM__MODE_START = 0x0087,
|
||
|
RESULT__INTERRUPT_STATUS = 0x0088,
|
||
|
RESULT__RANGE_STATUS = 0x0089,
|
||
|
RESULT__REPORT_STATUS = 0x008A,
|
||
|
RESULT__STREAM_COUNT = 0x008B,
|
||
|
RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0 = 0x008C,
|
||
|
RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0_HI = 0x008C,
|
||
|
RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0_LO = 0x008D,
|
||
|
RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD0 = 0x008E,
|
||
|
RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD0_HI = 0x008E,
|
||
|
RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD0_LO = 0x008F,
|
||
|
RESULT__AMBIENT_COUNT_RATE_MCPS_SD0 = 0x0090,
|
||
|
RESULT__AMBIENT_COUNT_RATE_MCPS_SD0_HI = 0x0090,
|
||
|
RESULT__AMBIENT_COUNT_RATE_MCPS_SD0_LO = 0x0091,
|
||
|
RESULT__SIGMA_SD0 = 0x0092,
|
||
|
RESULT__SIGMA_SD0_HI = 0x0092,
|
||
|
RESULT__SIGMA_SD0_LO = 0x0093,
|
||
|
RESULT__PHASE_SD0 = 0x0094,
|
||
|
RESULT__PHASE_SD0_HI = 0x0094,
|
||
|
RESULT__PHASE_SD0_LO = 0x0095,
|
||
|
RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0 = 0x0096,
|
||
|
RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0_HI = 0x0096,
|
||
|
RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0_LO = 0x0097,
|
||
|
RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0 = 0x0098,
|
||
|
RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0_HI = 0x0098,
|
||
|
RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0_LO = 0x0099,
|
||
|
RESULT__MM_INNER_ACTUAL_EFFECTIVE_SPADS_SD0 = 0x009A,
|
||
|
RESULT__MM_INNER_ACTUAL_EFFECTIVE_SPADS_SD0_HI = 0x009A,
|
||
|
RESULT__MM_INNER_ACTUAL_EFFECTIVE_SPADS_SD0_LO = 0x009B,
|
||
|
RESULT__MM_OUTER_ACTUAL_EFFECTIVE_SPADS_SD0 = 0x009C,
|
||
|
RESULT__MM_OUTER_ACTUAL_EFFECTIVE_SPADS_SD0_HI = 0x009C,
|
||
|
RESULT__MM_OUTER_ACTUAL_EFFECTIVE_SPADS_SD0_LO = 0x009D,
|
||
|
RESULT__AVG_SIGNAL_COUNT_RATE_MCPS_SD0 = 0x009E,
|
||
|
RESULT__AVG_SIGNAL_COUNT_RATE_MCPS_SD0_HI = 0x009E,
|
||
|
RESULT__AVG_SIGNAL_COUNT_RATE_MCPS_SD0_LO = 0x009F,
|
||
|
RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD1 = 0x00A0,
|
||
|
RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD1_HI = 0x00A0,
|
||
|
RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD1_LO = 0x00A1,
|
||
|
RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD1 = 0x00A2,
|
||
|
RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD1_HI = 0x00A2,
|
||
|
RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD1_LO = 0x00A3,
|
||
|
RESULT__AMBIENT_COUNT_RATE_MCPS_SD1 = 0x00A4,
|
||
|
RESULT__AMBIENT_COUNT_RATE_MCPS_SD1_HI = 0x00A4,
|
||
|
RESULT__AMBIENT_COUNT_RATE_MCPS_SD1_LO = 0x00A5,
|
||
|
RESULT__SIGMA_SD1 = 0x00A6,
|
||
|
RESULT__SIGMA_SD1_HI = 0x00A6,
|
||
|
RESULT__SIGMA_SD1_LO = 0x00A7,
|
||
|
RESULT__PHASE_SD1 = 0x00A8,
|
||
|
RESULT__PHASE_SD1_HI = 0x00A8,
|
||
|
RESULT__PHASE_SD1_LO = 0x00A9,
|
||
|
RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD1 = 0x00AA,
|
||
|
RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD1_HI = 0x00AA,
|
||
|
RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD1_LO = 0x00AB,
|
||
|
RESULT__SPARE_0_SD1 = 0x00AC,
|
||
|
RESULT__SPARE_0_SD1_HI = 0x00AC,
|
||
|
RESULT__SPARE_0_SD1_LO = 0x00AD,
|
||
|
RESULT__SPARE_1_SD1 = 0x00AE,
|
||
|
RESULT__SPARE_1_SD1_HI = 0x00AE,
|
||
|
RESULT__SPARE_1_SD1_LO = 0x00AF,
|
||
|
RESULT__SPARE_2_SD1 = 0x00B0,
|
||
|
RESULT__SPARE_2_SD1_HI = 0x00B0,
|
||
|
RESULT__SPARE_2_SD1_LO = 0x00B1,
|
||
|
RESULT__SPARE_3_SD1 = 0x00B2,
|
||
|
RESULT__THRESH_INFO = 0x00B3,
|
||
|
RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0 = 0x00B4,
|
||
|
RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_3 = 0x00B4,
|
||
|
RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_2 = 0x00B5,
|
||
|
RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_1 = 0x00B6,
|
||
|
RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_0 = 0x00B7,
|
||
|
RESULT_CORE__RANGING_TOTAL_EVENTS_SD0 = 0x00B8,
|
||
|
RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_3 = 0x00B8,
|
||
|
RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_2 = 0x00B9,
|
||
|
RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_1 = 0x00BA,
|
||
|
RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_0 = 0x00BB,
|
||
|
RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0 = 0x00BC,
|
||
|
RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_3 = 0x00BC,
|
||
|
RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_2 = 0x00BD,
|
||
|
RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_1 = 0x00BE,
|
||
|
RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_0 = 0x00BF,
|
||
|
RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0 = 0x00C0,
|
||
|
RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_3 = 0x00C0,
|
||
|
RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_2 = 0x00C1,
|
||
|
RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_1 = 0x00C2,
|
||
|
RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_0 = 0x00C3,
|
||
|
RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1 = 0x00C4,
|
||
|
RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_3 = 0x00C4,
|
||
|
RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_2 = 0x00C5,
|
||
|
RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_1 = 0x00C6,
|
||
|
RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_0 = 0x00C7,
|
||
|
RESULT_CORE__RANGING_TOTAL_EVENTS_SD1 = 0x00C8,
|
||
|
RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_3 = 0x00C8,
|
||
|
RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_2 = 0x00C9,
|
||
|
RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_1 = 0x00CA,
|
||
|
RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_0 = 0x00CB,
|
||
|
RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1 = 0x00CC,
|
||
|
RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_3 = 0x00CC,
|
||
|
RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_2 = 0x00CD,
|
||
|
RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_1 = 0x00CE,
|
||
|
RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_0 = 0x00CF,
|
||
|
RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1 = 0x00D0,
|
||
|
RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_3 = 0x00D0,
|
||
|
RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_2 = 0x00D1,
|
||
|
RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_1 = 0x00D2,
|
||
|
RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_0 = 0x00D3,
|
||
|
RESULT_CORE__SPARE_0 = 0x00D4,
|
||
|
PHASECAL_RESULT__REFERENCE_PHASE = 0x00D6,
|
||
|
PHASECAL_RESULT__REFERENCE_PHASE_HI = 0x00D6,
|
||
|
PHASECAL_RESULT__REFERENCE_PHASE_LO = 0x00D7,
|
||
|
PHASECAL_RESULT__VCSEL_START = 0x00D8,
|
||
|
REF_SPAD_CHAR_RESULT__NUM_ACTUAL_REF_SPADS = 0x00D9,
|
||
|
REF_SPAD_CHAR_RESULT__REF_LOCATION = 0x00DA,
|
||
|
VHV_RESULT__COLDBOOT_STATUS = 0x00DB,
|
||
|
VHV_RESULT__SEARCH_RESULT = 0x00DC,
|
||
|
VHV_RESULT__LATEST_SETTING = 0x00DD,
|
||
|
RESULT__OSC_CALIBRATE_VAL = 0x00DE,
|
||
|
RESULT__OSC_CALIBRATE_VAL_HI = 0x00DE,
|
||
|
RESULT__OSC_CALIBRATE_VAL_LO = 0x00DF,
|
||
|
ANA_CONFIG__POWERDOWN_GO1 = 0x00E0,
|
||
|
ANA_CONFIG__REF_BG_CTRL = 0x00E1,
|
||
|
ANA_CONFIG__REGDVDD1V2_CTRL = 0x00E2,
|
||
|
ANA_CONFIG__OSC_SLOW_CTRL = 0x00E3,
|
||
|
TEST_MODE__STATUS = 0x00E4,
|
||
|
FIRMWARE__SYSTEM_STATUS = 0x00E5,
|
||
|
FIRMWARE__MODE_STATUS = 0x00E6,
|
||
|
FIRMWARE__SECONDARY_MODE_STATUS = 0x00E7,
|
||
|
FIRMWARE__CAL_REPEAT_RATE_COUNTER = 0x00E8,
|
||
|
FIRMWARE__CAL_REPEAT_RATE_COUNTER_HI = 0x00E8,
|
||
|
FIRMWARE__CAL_REPEAT_RATE_COUNTER_LO = 0x00E9,
|
||
|
FIRMWARE__HISTOGRAM_BIN = 0x00EA,
|
||
|
GPH__SYSTEM__THRESH_HIGH = 0x00EC,
|
||
|
GPH__SYSTEM__THRESH_HIGH_HI = 0x00EC,
|
||
|
GPH__SYSTEM__THRESH_HIGH_LO = 0x00ED,
|
||
|
GPH__SYSTEM__THRESH_LOW = 0x00EE,
|
||
|
GPH__SYSTEM__THRESH_LOW_HI = 0x00EE,
|
||
|
GPH__SYSTEM__THRESH_LOW_LO = 0x00EF,
|
||
|
GPH__SYSTEM__ENABLE_XTALK_PER_QUADRANT = 0x00F0,
|
||
|
GPH__SPARE_0 = 0x00F1,
|
||
|
GPH__SD_CONFIG__WOI_SD0 = 0x00F2,
|
||
|
GPH__SD_CONFIG__WOI_SD1 = 0x00F3,
|
||
|
GPH__SD_CONFIG__INITIAL_PHASE_SD0 = 0x00F4,
|
||
|
GPH__SD_CONFIG__INITIAL_PHASE_SD1 = 0x00F5,
|
||
|
GPH__SD_CONFIG__FIRST_ORDER_SELECT = 0x00F6,
|
||
|
GPH__SD_CONFIG__QUANTIFIER = 0x00F7,
|
||
|
GPH__ROI_CONFIG__USER_ROI_CENTRE_SPAD = 0x00F8,
|
||
|
GPH__ROI_CONFIG__USER_ROI_REQUESTED_GLOBAL_XY_SIZE = 0x00F9,
|
||
|
GPH__SYSTEM__SEQUENCE_CONFIG = 0x00FA,
|
||
|
GPH__GPH_ID = 0x00FB,
|
||
|
SYSTEM__INTERRUPT_SET = 0x00FC,
|
||
|
INTERRUPT_MANAGER__ENABLES = 0x00FD,
|
||
|
INTERRUPT_MANAGER__CLEAR = 0x00FE,
|
||
|
INTERRUPT_MANAGER__STATUS = 0x00FF,
|
||
|
MCU_TO_HOST_BANK__WR_ACCESS_EN = 0x0100,
|
||
|
POWER_MANAGEMENT__GO1_RESET_STATUS = 0x0101,
|
||
|
PAD_STARTUP_MODE__VALUE_RO = 0x0102,
|
||
|
PAD_STARTUP_MODE__VALUE_CTRL = 0x0103,
|
||
|
PLL_PERIOD_US = 0x0104,
|
||
|
PLL_PERIOD_US_3 = 0x0104,
|
||
|
PLL_PERIOD_US_2 = 0x0105,
|
||
|
PLL_PERIOD_US_1 = 0x0106,
|
||
|
PLL_PERIOD_US_0 = 0x0107,
|
||
|
INTERRUPT_SCHEDULER__DATA_OUT = 0x0108,
|
||
|
INTERRUPT_SCHEDULER__DATA_OUT_3 = 0x0108,
|
||
|
INTERRUPT_SCHEDULER__DATA_OUT_2 = 0x0109,
|
||
|
INTERRUPT_SCHEDULER__DATA_OUT_1 = 0x010A,
|
||
|
INTERRUPT_SCHEDULER__DATA_OUT_0 = 0x010B,
|
||
|
NVM_BIST__COMPLETE = 0x010C,
|
||
|
NVM_BIST__STATUS = 0x010D,
|
||
|
IDENTIFICATION__MODEL_ID = 0x010F,
|
||
|
IDENTIFICATION__MODULE_TYPE = 0x0110,
|
||
|
IDENTIFICATION__REVISION_ID = 0x0111,
|
||
|
IDENTIFICATION__MODULE_ID = 0x0112,
|
||
|
IDENTIFICATION__MODULE_ID_HI = 0x0112,
|
||
|
IDENTIFICATION__MODULE_ID_LO = 0x0113,
|
||
|
ANA_CONFIG__FAST_OSC__TRIM_MAX = 0x0114,
|
||
|
ANA_CONFIG__FAST_OSC__FREQ_SET = 0x0115,
|
||
|
ANA_CONFIG__VCSEL_TRIM = 0x0116,
|
||
|
ANA_CONFIG__VCSEL_SELION = 0x0117,
|
||
|
ANA_CONFIG__VCSEL_SELION_MAX = 0x0118,
|
||
|
PROTECTED_LASER_SAFETY__LOCK_BIT = 0x0119,
|
||
|
LASER_SAFETY__KEY = 0x011A,
|
||
|
LASER_SAFETY__KEY_RO = 0x011B,
|
||
|
LASER_SAFETY__CLIP = 0x011C,
|
||
|
LASER_SAFETY__MULT = 0x011D,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_0 = 0x011E,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_1 = 0x011F,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_2 = 0x0120,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_3 = 0x0121,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_4 = 0x0122,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_5 = 0x0123,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_6 = 0x0124,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_7 = 0x0125,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_8 = 0x0126,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_9 = 0x0127,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_10 = 0x0128,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_11 = 0x0129,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_12 = 0x012A,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_13 = 0x012B,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_14 = 0x012C,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_15 = 0x012D,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_16 = 0x012E,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_17 = 0x012F,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_18 = 0x0130,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_19 = 0x0131,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_20 = 0x0132,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_21 = 0x0133,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_22 = 0x0134,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_23 = 0x0135,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_24 = 0x0136,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_25 = 0x0137,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_26 = 0x0138,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_27 = 0x0139,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_28 = 0x013A,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_29 = 0x013B,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_30 = 0x013C,
|
||
|
GLOBAL_CONFIG__SPAD_ENABLES_RTN_31 = 0x013D,
|
||
|
ROI_CONFIG__MODE_ROI_CENTRE_SPAD = 0x013E,
|
||
|
ROI_CONFIG__MODE_ROI_XY_SIZE = 0x013F,
|
||
|
GO2_HOST_BANK_ACCESS__OVERRIDE = 0x0300,
|
||
|
MCU_UTIL_MULTIPLIER__MULTIPLICAND = 0x0400,
|
||
|
MCU_UTIL_MULTIPLIER__MULTIPLICAND_3 = 0x0400,
|
||
|
MCU_UTIL_MULTIPLIER__MULTIPLICAND_2 = 0x0401,
|
||
|
MCU_UTIL_MULTIPLIER__MULTIPLICAND_1 = 0x0402,
|
||
|
MCU_UTIL_MULTIPLIER__MULTIPLICAND_0 = 0x0403,
|
||
|
MCU_UTIL_MULTIPLIER__MULTIPLIER = 0x0404,
|
||
|
MCU_UTIL_MULTIPLIER__MULTIPLIER_3 = 0x0404,
|
||
|
MCU_UTIL_MULTIPLIER__MULTIPLIER_2 = 0x0405,
|
||
|
MCU_UTIL_MULTIPLIER__MULTIPLIER_1 = 0x0406,
|
||
|
MCU_UTIL_MULTIPLIER__MULTIPLIER_0 = 0x0407,
|
||
|
MCU_UTIL_MULTIPLIER__PRODUCT_HI = 0x0408,
|
||
|
MCU_UTIL_MULTIPLIER__PRODUCT_HI_3 = 0x0408,
|
||
|
MCU_UTIL_MULTIPLIER__PRODUCT_HI_2 = 0x0409,
|
||
|
MCU_UTIL_MULTIPLIER__PRODUCT_HI_1 = 0x040A,
|
||
|
MCU_UTIL_MULTIPLIER__PRODUCT_HI_0 = 0x040B,
|
||
|
MCU_UTIL_MULTIPLIER__PRODUCT_LO = 0x040C,
|
||
|
MCU_UTIL_MULTIPLIER__PRODUCT_LO_3 = 0x040C,
|
||
|
MCU_UTIL_MULTIPLIER__PRODUCT_LO_2 = 0x040D,
|
||
|
MCU_UTIL_MULTIPLIER__PRODUCT_LO_1 = 0x040E,
|
||
|
MCU_UTIL_MULTIPLIER__PRODUCT_LO_0 = 0x040F,
|
||
|
MCU_UTIL_MULTIPLIER__START = 0x0410,
|
||
|
MCU_UTIL_MULTIPLIER__STATUS = 0x0411,
|
||
|
MCU_UTIL_DIVIDER__START = 0x0412,
|
||
|
MCU_UTIL_DIVIDER__STATUS = 0x0413,
|
||
|
MCU_UTIL_DIVIDER__DIVIDEND = 0x0414,
|
||
|
MCU_UTIL_DIVIDER__DIVIDEND_3 = 0x0414,
|
||
|
MCU_UTIL_DIVIDER__DIVIDEND_2 = 0x0415,
|
||
|
MCU_UTIL_DIVIDER__DIVIDEND_1 = 0x0416,
|
||
|
MCU_UTIL_DIVIDER__DIVIDEND_0 = 0x0417,
|
||
|
MCU_UTIL_DIVIDER__DIVISOR = 0x0418,
|
||
|
MCU_UTIL_DIVIDER__DIVISOR_3 = 0x0418,
|
||
|
MCU_UTIL_DIVIDER__DIVISOR_2 = 0x0419,
|
||
|
MCU_UTIL_DIVIDER__DIVISOR_1 = 0x041A,
|
||
|
MCU_UTIL_DIVIDER__DIVISOR_0 = 0x041B,
|
||
|
MCU_UTIL_DIVIDER__QUOTIENT = 0x041C,
|
||
|
MCU_UTIL_DIVIDER__QUOTIENT_3 = 0x041C,
|
||
|
MCU_UTIL_DIVIDER__QUOTIENT_2 = 0x041D,
|
||
|
MCU_UTIL_DIVIDER__QUOTIENT_1 = 0x041E,
|
||
|
MCU_UTIL_DIVIDER__QUOTIENT_0 = 0x041F,
|
||
|
TIMER0__VALUE_IN = 0x0420,
|
||
|
TIMER0__VALUE_IN_3 = 0x0420,
|
||
|
TIMER0__VALUE_IN_2 = 0x0421,
|
||
|
TIMER0__VALUE_IN_1 = 0x0422,
|
||
|
TIMER0__VALUE_IN_0 = 0x0423,
|
||
|
TIMER1__VALUE_IN = 0x0424,
|
||
|
TIMER1__VALUE_IN_3 = 0x0424,
|
||
|
TIMER1__VALUE_IN_2 = 0x0425,
|
||
|
TIMER1__VALUE_IN_1 = 0x0426,
|
||
|
TIMER1__VALUE_IN_0 = 0x0427,
|
||
|
TIMER0__CTRL = 0x0428,
|
||
|
TIMER1__CTRL = 0x0429,
|
||
|
MCU_GENERAL_PURPOSE__GP_0 = 0x042C,
|
||
|
MCU_GENERAL_PURPOSE__GP_1 = 0x042D,
|
||
|
MCU_GENERAL_PURPOSE__GP_2 = 0x042E,
|
||
|
MCU_GENERAL_PURPOSE__GP_3 = 0x042F,
|
||
|
MCU_RANGE_CALC__CONFIG = 0x0430,
|
||
|
MCU_RANGE_CALC__OFFSET_CORRECTED_RANGE = 0x0432,
|
||
|
MCU_RANGE_CALC__OFFSET_CORRECTED_RANGE_HI = 0x0432,
|
||
|
MCU_RANGE_CALC__OFFSET_CORRECTED_RANGE_LO = 0x0433,
|
||
|
MCU_RANGE_CALC__SPARE_4 = 0x0434,
|
||
|
MCU_RANGE_CALC__SPARE_4_3 = 0x0434,
|
||
|
MCU_RANGE_CALC__SPARE_4_2 = 0x0435,
|
||
|
MCU_RANGE_CALC__SPARE_4_1 = 0x0436,
|
||
|
MCU_RANGE_CALC__SPARE_4_0 = 0x0437,
|
||
|
MCU_RANGE_CALC__AMBIENT_DURATION_PRE_CALC = 0x0438,
|
||
|
MCU_RANGE_CALC__AMBIENT_DURATION_PRE_CALC_HI = 0x0438,
|
||
|
MCU_RANGE_CALC__AMBIENT_DURATION_PRE_CALC_LO = 0x0439,
|
||
|
MCU_RANGE_CALC__ALGO_VCSEL_PERIOD = 0x043C,
|
||
|
MCU_RANGE_CALC__SPARE_5 = 0x043D,
|
||
|
MCU_RANGE_CALC__ALGO_TOTAL_PERIODS = 0x043E,
|
||
|
MCU_RANGE_CALC__ALGO_TOTAL_PERIODS_HI = 0x043E,
|
||
|
MCU_RANGE_CALC__ALGO_TOTAL_PERIODS_LO = 0x043F,
|
||
|
MCU_RANGE_CALC__ALGO_ACCUM_PHASE = 0x0440,
|
||
|
MCU_RANGE_CALC__ALGO_ACCUM_PHASE_3 = 0x0440,
|
||
|
MCU_RANGE_CALC__ALGO_ACCUM_PHASE_2 = 0x0441,
|
||
|
MCU_RANGE_CALC__ALGO_ACCUM_PHASE_1 = 0x0442,
|
||
|
MCU_RANGE_CALC__ALGO_ACCUM_PHASE_0 = 0x0443,
|
||
|
MCU_RANGE_CALC__ALGO_SIGNAL_EVENTS = 0x0444,
|
||
|
MCU_RANGE_CALC__ALGO_SIGNAL_EVENTS_3 = 0x0444,
|
||
|
MCU_RANGE_CALC__ALGO_SIGNAL_EVENTS_2 = 0x0445,
|
||
|
MCU_RANGE_CALC__ALGO_SIGNAL_EVENTS_1 = 0x0446,
|
||
|
MCU_RANGE_CALC__ALGO_SIGNAL_EVENTS_0 = 0x0447,
|
||
|
MCU_RANGE_CALC__ALGO_AMBIENT_EVENTS = 0x0448,
|
||
|
MCU_RANGE_CALC__ALGO_AMBIENT_EVENTS_3 = 0x0448,
|
||
|
MCU_RANGE_CALC__ALGO_AMBIENT_EVENTS_2 = 0x0449,
|
||
|
MCU_RANGE_CALC__ALGO_AMBIENT_EVENTS_1 = 0x044A,
|
||
|
MCU_RANGE_CALC__ALGO_AMBIENT_EVENTS_0 = 0x044B,
|
||
|
MCU_RANGE_CALC__SPARE_6 = 0x044C,
|
||
|
MCU_RANGE_CALC__SPARE_6_HI = 0x044C,
|
||
|
MCU_RANGE_CALC__SPARE_6_LO = 0x044D,
|
||
|
MCU_RANGE_CALC__ALGO_ADJUST_VCSEL_PERIOD = 0x044E,
|
||
|
MCU_RANGE_CALC__ALGO_ADJUST_VCSEL_PERIOD_HI = 0x044E,
|
||
|
MCU_RANGE_CALC__ALGO_ADJUST_VCSEL_PERIOD_LO = 0x044F,
|
||
|
MCU_RANGE_CALC__NUM_SPADS = 0x0450,
|
||
|
MCU_RANGE_CALC__NUM_SPADS_HI = 0x0450,
|
||
|
MCU_RANGE_CALC__NUM_SPADS_LO = 0x0451,
|
||
|
MCU_RANGE_CALC__PHASE_OUTPUT = 0x0452,
|
||
|
MCU_RANGE_CALC__PHASE_OUTPUT_HI = 0x0452,
|
||
|
MCU_RANGE_CALC__PHASE_OUTPUT_LO = 0x0453,
|
||
|
MCU_RANGE_CALC__RATE_PER_SPAD_MCPS = 0x0454,
|
||
|
MCU_RANGE_CALC__RATE_PER_SPAD_MCPS_3 = 0x0454,
|
||
|
MCU_RANGE_CALC__RATE_PER_SPAD_MCPS_2 = 0x0455,
|
||
|
MCU_RANGE_CALC__RATE_PER_SPAD_MCPS_1 = 0x0456,
|
||
|
MCU_RANGE_CALC__RATE_PER_SPAD_MCPS_0 = 0x0457,
|
||
|
MCU_RANGE_CALC__SPARE_7 = 0x0458,
|
||
|
MCU_RANGE_CALC__SPARE_8 = 0x0459,
|
||
|
MCU_RANGE_CALC__PEAK_SIGNAL_RATE_MCPS = 0x045A,
|
||
|
MCU_RANGE_CALC__PEAK_SIGNAL_RATE_MCPS_HI = 0x045A,
|
||
|
MCU_RANGE_CALC__PEAK_SIGNAL_RATE_MCPS_LO = 0x045B,
|
||
|
MCU_RANGE_CALC__AVG_SIGNAL_RATE_MCPS = 0x045C,
|
||
|
MCU_RANGE_CALC__AVG_SIGNAL_RATE_MCPS_HI = 0x045C,
|
||
|
MCU_RANGE_CALC__AVG_SIGNAL_RATE_MCPS_LO = 0x045D,
|
||
|
MCU_RANGE_CALC__AMBIENT_RATE_MCPS = 0x045E,
|
||
|
MCU_RANGE_CALC__AMBIENT_RATE_MCPS_HI = 0x045E,
|
||
|
MCU_RANGE_CALC__AMBIENT_RATE_MCPS_LO = 0x045F,
|
||
|
MCU_RANGE_CALC__XTALK = 0x0460,
|
||
|
MCU_RANGE_CALC__XTALK_HI = 0x0460,
|
||
|
MCU_RANGE_CALC__XTALK_LO = 0x0461,
|
||
|
MCU_RANGE_CALC__CALC_STATUS = 0x0462,
|
||
|
MCU_RANGE_CALC__DEBUG = 0x0463,
|
||
|
MCU_RANGE_CALC__PEAK_SIGNAL_RATE_XTALK_CORR_MCPS = 0x0464,
|
||
|
MCU_RANGE_CALC__PEAK_SIGNAL_RATE_XTALK_CORR_MCPS_HI = 0x0464,
|
||
|
MCU_RANGE_CALC__PEAK_SIGNAL_RATE_XTALK_CORR_MCPS_LO = 0x0465,
|
||
|
MCU_RANGE_CALC__SPARE_0 = 0x0468,
|
||
|
MCU_RANGE_CALC__SPARE_1 = 0x0469,
|
||
|
MCU_RANGE_CALC__SPARE_2 = 0x046A,
|
||
|
MCU_RANGE_CALC__SPARE_3 = 0x046B,
|
||
|
PATCH__CTRL = 0x0470,
|
||
|
PATCH__JMP_ENABLES = 0x0472,
|
||
|
PATCH__JMP_ENABLES_HI = 0x0472,
|
||
|
PATCH__JMP_ENABLES_LO = 0x0473,
|
||
|
PATCH__DATA_ENABLES = 0x0474,
|
||
|
PATCH__DATA_ENABLES_HI = 0x0474,
|
||
|
PATCH__DATA_ENABLES_LO = 0x0475,
|
||
|
PATCH__OFFSET_0 = 0x0476,
|
||
|
PATCH__OFFSET_0_HI = 0x0476,
|
||
|
PATCH__OFFSET_0_LO = 0x0477,
|
||
|
PATCH__OFFSET_1 = 0x0478,
|
||
|
PATCH__OFFSET_1_HI = 0x0478,
|
||
|
PATCH__OFFSET_1_LO = 0x0479,
|
||
|
PATCH__OFFSET_2 = 0x047A,
|
||
|
PATCH__OFFSET_2_HI = 0x047A,
|
||
|
PATCH__OFFSET_2_LO = 0x047B,
|
||
|
PATCH__OFFSET_3 = 0x047C,
|
||
|
PATCH__OFFSET_3_HI = 0x047C,
|
||
|
PATCH__OFFSET_3_LO = 0x047D,
|
||
|
PATCH__OFFSET_4 = 0x047E,
|
||
|
PATCH__OFFSET_4_HI = 0x047E,
|
||
|
PATCH__OFFSET_4_LO = 0x047F,
|
||
|
PATCH__OFFSET_5 = 0x0480,
|
||
|
PATCH__OFFSET_5_HI = 0x0480,
|
||
|
PATCH__OFFSET_5_LO = 0x0481,
|
||
|
PATCH__OFFSET_6 = 0x0482,
|
||
|
PATCH__OFFSET_6_HI = 0x0482,
|
||
|
PATCH__OFFSET_6_LO = 0x0483,
|
||
|
PATCH__OFFSET_7 = 0x0484,
|
||
|
PATCH__OFFSET_7_HI = 0x0484,
|
||
|
PATCH__OFFSET_7_LO = 0x0485,
|
||
|
PATCH__OFFSET_8 = 0x0486,
|
||
|
PATCH__OFFSET_8_HI = 0x0486,
|
||
|
PATCH__OFFSET_8_LO = 0x0487,
|
||
|
PATCH__OFFSET_9 = 0x0488,
|
||
|
PATCH__OFFSET_9_HI = 0x0488,
|
||
|
PATCH__OFFSET_9_LO = 0x0489,
|
||
|
PATCH__OFFSET_10 = 0x048A,
|
||
|
PATCH__OFFSET_10_HI = 0x048A,
|
||
|
PATCH__OFFSET_10_LO = 0x048B,
|
||
|
PATCH__OFFSET_11 = 0x048C,
|
||
|
PATCH__OFFSET_11_HI = 0x048C,
|
||
|
PATCH__OFFSET_11_LO = 0x048D,
|
||
|
PATCH__OFFSET_12 = 0x048E,
|
||
|
PATCH__OFFSET_12_HI = 0x048E,
|
||
|
PATCH__OFFSET_12_LO = 0x048F,
|
||
|
PATCH__OFFSET_13 = 0x0490,
|
||
|
PATCH__OFFSET_13_HI = 0x0490,
|
||
|
PATCH__OFFSET_13_LO = 0x0491,
|
||
|
PATCH__OFFSET_14 = 0x0492,
|
||
|
PATCH__OFFSET_14_HI = 0x0492,
|
||
|
PATCH__OFFSET_14_LO = 0x0493,
|
||
|
PATCH__OFFSET_15 = 0x0494,
|
||
|
PATCH__OFFSET_15_HI = 0x0494,
|
||
|
PATCH__OFFSET_15_LO = 0x0495,
|
||
|
PATCH__ADDRESS_0 = 0x0496,
|
||
|
PATCH__ADDRESS_0_HI = 0x0496,
|
||
|
PATCH__ADDRESS_0_LO = 0x0497,
|
||
|
PATCH__ADDRESS_1 = 0x0498,
|
||
|
PATCH__ADDRESS_1_HI = 0x0498,
|
||
|
PATCH__ADDRESS_1_LO = 0x0499,
|
||
|
PATCH__ADDRESS_2 = 0x049A,
|
||
|
PATCH__ADDRESS_2_HI = 0x049A,
|
||
|
PATCH__ADDRESS_2_LO = 0x049B,
|
||
|
PATCH__ADDRESS_3 = 0x049C,
|
||
|
PATCH__ADDRESS_3_HI = 0x049C,
|
||
|
PATCH__ADDRESS_3_LO = 0x049D,
|
||
|
PATCH__ADDRESS_4 = 0x049E,
|
||
|
PATCH__ADDRESS_4_HI = 0x049E,
|
||
|
PATCH__ADDRESS_4_LO = 0x049F,
|
||
|
PATCH__ADDRESS_5 = 0x04A0,
|
||
|
PATCH__ADDRESS_5_HI = 0x04A0,
|
||
|
PATCH__ADDRESS_5_LO = 0x04A1,
|
||
|
PATCH__ADDRESS_6 = 0x04A2,
|
||
|
PATCH__ADDRESS_6_HI = 0x04A2,
|
||
|
PATCH__ADDRESS_6_LO = 0x04A3,
|
||
|
PATCH__ADDRESS_7 = 0x04A4,
|
||
|
PATCH__ADDRESS_7_HI = 0x04A4,
|
||
|
PATCH__ADDRESS_7_LO = 0x04A5,
|
||
|
PATCH__ADDRESS_8 = 0x04A6,
|
||
|
PATCH__ADDRESS_8_HI = 0x04A6,
|
||
|
PATCH__ADDRESS_8_LO = 0x04A7,
|
||
|
PATCH__ADDRESS_9 = 0x04A8,
|
||
|
PATCH__ADDRESS_9_HI = 0x04A8,
|
||
|
PATCH__ADDRESS_9_LO = 0x04A9,
|
||
|
PATCH__ADDRESS_10 = 0x04AA,
|
||
|
PATCH__ADDRESS_10_HI = 0x04AA,
|
||
|
PATCH__ADDRESS_10_LO = 0x04AB,
|
||
|
PATCH__ADDRESS_11 = 0x04AC,
|
||
|
PATCH__ADDRESS_11_HI = 0x04AC,
|
||
|
PATCH__ADDRESS_11_LO = 0x04AD,
|
||
|
PATCH__ADDRESS_12 = 0x04AE,
|
||
|
PATCH__ADDRESS_12_HI = 0x04AE,
|
||
|
PATCH__ADDRESS_12_LO = 0x04AF,
|
||
|
PATCH__ADDRESS_13 = 0x04B0,
|
||
|
PATCH__ADDRESS_13_HI = 0x04B0,
|
||
|
PATCH__ADDRESS_13_LO = 0x04B1,
|
||
|
PATCH__ADDRESS_14 = 0x04B2,
|
||
|
PATCH__ADDRESS_14_HI = 0x04B2,
|
||
|
PATCH__ADDRESS_14_LO = 0x04B3,
|
||
|
PATCH__ADDRESS_15 = 0x04B4,
|
||
|
PATCH__ADDRESS_15_HI = 0x04B4,
|
||
|
PATCH__ADDRESS_15_LO = 0x04B5,
|
||
|
SPI_ASYNC_MUX__CTRL = 0x04C0,
|
||
|
CLK__CONFIG = 0x04C4,
|
||
|
GPIO_LV_MUX__CTRL = 0x04CC,
|
||
|
GPIO_LV_PAD__CTRL = 0x04CD,
|
||
|
PAD_I2C_LV__CONFIG = 0x04D0,
|
||
|
PAD_STARTUP_MODE__VALUE_RO_GO1 = 0x04D4,
|
||
|
HOST_IF__STATUS_GO1 = 0x04D5,
|
||
|
MCU_CLK_GATING__CTRL = 0x04D8,
|
||
|
TEST__BIST_ROM_CTRL = 0x04E0,
|
||
|
TEST__BIST_ROM_RESULT = 0x04E1,
|
||
|
TEST__BIST_ROM_MCU_SIG = 0x04E2,
|
||
|
TEST__BIST_ROM_MCU_SIG_HI = 0x04E2,
|
||
|
TEST__BIST_ROM_MCU_SIG_LO = 0x04E3,
|
||
|
TEST__BIST_RAM_CTRL = 0x04E4,
|
||
|
TEST__BIST_RAM_RESULT = 0x04E5,
|
||
|
TEST__TMC = 0x04E8,
|
||
|
TEST__PLL_BIST_MIN_THRESHOLD = 0x04F0,
|
||
|
TEST__PLL_BIST_MIN_THRESHOLD_HI = 0x04F0,
|
||
|
TEST__PLL_BIST_MIN_THRESHOLD_LO = 0x04F1,
|
||
|
TEST__PLL_BIST_MAX_THRESHOLD = 0x04F2,
|
||
|
TEST__PLL_BIST_MAX_THRESHOLD_HI = 0x04F2,
|
||
|
TEST__PLL_BIST_MAX_THRESHOLD_LO = 0x04F3,
|
||
|
TEST__PLL_BIST_COUNT_OUT = 0x04F4,
|
||
|
TEST__PLL_BIST_COUNT_OUT_HI = 0x04F4,
|
||
|
TEST__PLL_BIST_COUNT_OUT_LO = 0x04F5,
|
||
|
TEST__PLL_BIST_GONOGO = 0x04F6,
|
||
|
TEST__PLL_BIST_CTRL = 0x04F7,
|
||
|
RANGING_CORE__DEVICE_ID = 0x0680,
|
||
|
RANGING_CORE__REVISION_ID = 0x0681,
|
||
|
RANGING_CORE__CLK_CTRL1 = 0x0683,
|
||
|
RANGING_CORE__CLK_CTRL2 = 0x0684,
|
||
|
RANGING_CORE__WOI_1 = 0x0685,
|
||
|
RANGING_CORE__WOI_REF_1 = 0x0686,
|
||
|
RANGING_CORE__START_RANGING = 0x0687,
|
||
|
RANGING_CORE__LOW_LIMIT_1 = 0x0690,
|
||
|
RANGING_CORE__HIGH_LIMIT_1 = 0x0691,
|
||
|
RANGING_CORE__LOW_LIMIT_REF_1 = 0x0692,
|
||
|
RANGING_CORE__HIGH_LIMIT_REF_1 = 0x0693,
|
||
|
RANGING_CORE__QUANTIFIER_1_MSB = 0x0694,
|
||
|
RANGING_CORE__QUANTIFIER_1_LSB = 0x0695,
|
||
|
RANGING_CORE__QUANTIFIER_REF_1_MSB = 0x0696,
|
||
|
RANGING_CORE__QUANTIFIER_REF_1_LSB = 0x0697,
|
||
|
RANGING_CORE__AMBIENT_OFFSET_1_MSB = 0x0698,
|
||
|
RANGING_CORE__AMBIENT_OFFSET_1_LSB = 0x0699,
|
||
|
RANGING_CORE__AMBIENT_OFFSET_REF_1_MSB = 0x069A,
|
||
|
RANGING_CORE__AMBIENT_OFFSET_REF_1_LSB = 0x069B,
|
||
|
RANGING_CORE__FILTER_STRENGTH_1 = 0x069C,
|
||
|
RANGING_CORE__FILTER_STRENGTH_REF_1 = 0x069D,
|
||
|
RANGING_CORE__SIGNAL_EVENT_LIMIT_1_MSB = 0x069E,
|
||
|
RANGING_CORE__SIGNAL_EVENT_LIMIT_1_LSB = 0x069F,
|
||
|
RANGING_CORE__SIGNAL_EVENT_LIMIT_REF_1_MSB = 0x06A0,
|
||
|
RANGING_CORE__SIGNAL_EVENT_LIMIT_REF_1_LSB = 0x06A1,
|
||
|
RANGING_CORE__TIMEOUT_OVERALL_PERIODS_MSB = 0x06A4,
|
||
|
RANGING_CORE__TIMEOUT_OVERALL_PERIODS_LSB = 0x06A5,
|
||
|
RANGING_CORE__INVERT_HW = 0x06A6,
|
||
|
RANGING_CORE__FORCE_HW = 0x06A7,
|
||
|
RANGING_CORE__STATIC_HW_VALUE = 0x06A8,
|
||
|
RANGING_CORE__FORCE_CONTINUOUS_AMBIENT = 0x06A9,
|
||
|
RANGING_CORE__TEST_PHASE_SELECT_TO_FILTER = 0x06AA,
|
||
|
RANGING_CORE__TEST_PHASE_SELECT_TO_TIMING_GEN = 0x06AB,
|
||
|
RANGING_CORE__INITIAL_PHASE_VALUE_1 = 0x06AC,
|
||
|
RANGING_CORE__INITIAL_PHASE_VALUE_REF_1 = 0x06AD,
|
||
|
RANGING_CORE__FORCE_UP_IN = 0x06AE,
|
||
|
RANGING_CORE__FORCE_DN_IN = 0x06AF,
|
||
|
RANGING_CORE__STATIC_UP_VALUE_1 = 0x06B0,
|
||
|
RANGING_CORE__STATIC_UP_VALUE_REF_1 = 0x06B1,
|
||
|
RANGING_CORE__STATIC_DN_VALUE_1 = 0x06B2,
|
||
|
RANGING_CORE__STATIC_DN_VALUE_REF_1 = 0x06B3,
|
||
|
RANGING_CORE__MONITOR_UP_DN = 0x06B4,
|
||
|
RANGING_CORE__INVERT_UP_DN = 0x06B5,
|
||
|
RANGING_CORE__CPUMP_1 = 0x06B6,
|
||
|
RANGING_CORE__CPUMP_2 = 0x06B7,
|
||
|
RANGING_CORE__CPUMP_3 = 0x06B8,
|
||
|
RANGING_CORE__OSC_1 = 0x06B9,
|
||
|
RANGING_CORE__PLL_1 = 0x06BB,
|
||
|
RANGING_CORE__PLL_2 = 0x06BC,
|
||
|
RANGING_CORE__REFERENCE_1 = 0x06BD,
|
||
|
RANGING_CORE__REFERENCE_3 = 0x06BF,
|
||
|
RANGING_CORE__REFERENCE_4 = 0x06C0,
|
||
|
RANGING_CORE__REFERENCE_5 = 0x06C1,
|
||
|
RANGING_CORE__REGAVDD1V2 = 0x06C3,
|
||
|
RANGING_CORE__CALIB_1 = 0x06C4,
|
||
|
RANGING_CORE__CALIB_2 = 0x06C5,
|
||
|
RANGING_CORE__CALIB_3 = 0x06C6,
|
||
|
RANGING_CORE__TST_MUX_SEL1 = 0x06C9,
|
||
|
RANGING_CORE__TST_MUX_SEL2 = 0x06CA,
|
||
|
RANGING_CORE__TST_MUX = 0x06CB,
|
||
|
RANGING_CORE__GPIO_OUT_TESTMUX = 0x06CC,
|
||
|
RANGING_CORE__CUSTOM_FE = 0x06CD,
|
||
|
RANGING_CORE__CUSTOM_FE_2 = 0x06CE,
|
||
|
RANGING_CORE__SPAD_READOUT = 0x06CF,
|
||
|
RANGING_CORE__SPAD_READOUT_1 = 0x06D0,
|
||
|
RANGING_CORE__SPAD_READOUT_2 = 0x06D1,
|
||
|
RANGING_CORE__SPAD_PS = 0x06D2,
|
||
|
RANGING_CORE__LASER_SAFETY_2 = 0x06D4,
|
||
|
RANGING_CORE__NVM_CTRL__MODE = 0x0780,
|
||
|
RANGING_CORE__NVM_CTRL__PDN = 0x0781,
|
||
|
RANGING_CORE__NVM_CTRL__PROGN = 0x0782,
|
||
|
RANGING_CORE__NVM_CTRL__READN = 0x0783,
|
||
|
RANGING_CORE__NVM_CTRL__PULSE_WIDTH_MSB = 0x0784,
|
||
|
RANGING_CORE__NVM_CTRL__PULSE_WIDTH_LSB = 0x0785,
|
||
|
RANGING_CORE__NVM_CTRL__HV_RISE_MSB = 0x0786,
|
||
|
RANGING_CORE__NVM_CTRL__HV_RISE_LSB = 0x0787,
|
||
|
RANGING_CORE__NVM_CTRL__HV_FALL_MSB = 0x0788,
|
||
|
RANGING_CORE__NVM_CTRL__HV_FALL_LSB = 0x0789,
|
||
|
RANGING_CORE__NVM_CTRL__TST = 0x078A,
|
||
|
RANGING_CORE__NVM_CTRL__TESTREAD = 0x078B,
|
||
|
RANGING_CORE__NVM_CTRL__DATAIN_MMM = 0x078C,
|
||
|
RANGING_CORE__NVM_CTRL__DATAIN_LMM = 0x078D,
|
||
|
RANGING_CORE__NVM_CTRL__DATAIN_LLM = 0x078E,
|
||
|
RANGING_CORE__NVM_CTRL__DATAIN_LLL = 0x078F,
|
||
|
RANGING_CORE__NVM_CTRL__DATAOUT_MMM = 0x0790,
|
||
|
RANGING_CORE__NVM_CTRL__DATAOUT_LMM = 0x0791,
|
||
|
RANGING_CORE__NVM_CTRL__DATAOUT_LLM = 0x0792,
|
||
|
RANGING_CORE__NVM_CTRL__DATAOUT_LLL = 0x0793,
|
||
|
RANGING_CORE__NVM_CTRL__ADDR = 0x0794,
|
||
|
RANGING_CORE__NVM_CTRL__DATAOUT_ECC = 0x0795,
|
||
|
RANGING_CORE__RET_SPAD_EN_0 = 0x0796,
|
||
|
RANGING_CORE__RET_SPAD_EN_1 = 0x0797,
|
||
|
RANGING_CORE__RET_SPAD_EN_2 = 0x0798,
|
||
|
RANGING_CORE__RET_SPAD_EN_3 = 0x0799,
|
||
|
RANGING_CORE__RET_SPAD_EN_4 = 0x079A,
|
||
|
RANGING_CORE__RET_SPAD_EN_5 = 0x079B,
|
||
|
RANGING_CORE__RET_SPAD_EN_6 = 0x079C,
|
||
|
RANGING_CORE__RET_SPAD_EN_7 = 0x079D,
|
||
|
RANGING_CORE__RET_SPAD_EN_8 = 0x079E,
|
||
|
RANGING_CORE__RET_SPAD_EN_9 = 0x079F,
|
||
|
RANGING_CORE__RET_SPAD_EN_10 = 0x07A0,
|
||
|
RANGING_CORE__RET_SPAD_EN_11 = 0x07A1,
|
||
|
RANGING_CORE__RET_SPAD_EN_12 = 0x07A2,
|
||
|
RANGING_CORE__RET_SPAD_EN_13 = 0x07A3,
|
||
|
RANGING_CORE__RET_SPAD_EN_14 = 0x07A4,
|
||
|
RANGING_CORE__RET_SPAD_EN_15 = 0x07A5,
|
||
|
RANGING_CORE__RET_SPAD_EN_16 = 0x07A6,
|
||
|
RANGING_CORE__RET_SPAD_EN_17 = 0x07A7,
|
||
|
RANGING_CORE__SPAD_SHIFT_EN = 0x07BA,
|
||
|
RANGING_CORE__SPAD_DISABLE_CTRL = 0x07BB,
|
||
|
RANGING_CORE__SPAD_EN_SHIFT_OUT_DEBUG = 0x07BC,
|
||
|
RANGING_CORE__SPI_MODE = 0x07BD,
|
||
|
RANGING_CORE__GPIO_DIR = 0x07BE,
|
||
|
RANGING_CORE__VCSEL_PERIOD = 0x0880,
|
||
|
RANGING_CORE__VCSEL_START = 0x0881,
|
||
|
RANGING_CORE__VCSEL_STOP = 0x0882,
|
||
|
RANGING_CORE__VCSEL_1 = 0x0885,
|
||
|
RANGING_CORE__VCSEL_STATUS = 0x088D,
|
||
|
RANGING_CORE__STATUS = 0x0980,
|
||
|
RANGING_CORE__LASER_CONTINUITY_STATE = 0x0981,
|
||
|
RANGING_CORE__RANGE_1_MMM = 0x0982,
|
||
|
RANGING_CORE__RANGE_1_LMM = 0x0983,
|
||
|
RANGING_CORE__RANGE_1_LLM = 0x0984,
|
||
|
RANGING_CORE__RANGE_1_LLL = 0x0985,
|
||
|
RANGING_CORE__RANGE_REF_1_MMM = 0x0986,
|
||
|
RANGING_CORE__RANGE_REF_1_LMM = 0x0987,
|
||
|
RANGING_CORE__RANGE_REF_1_LLM = 0x0988,
|
||
|
RANGING_CORE__RANGE_REF_1_LLL = 0x0989,
|
||
|
RANGING_CORE__AMBIENT_WINDOW_EVENTS_1_MMM = 0x098A,
|
||
|
RANGING_CORE__AMBIENT_WINDOW_EVENTS_1_LMM = 0x098B,
|
||
|
RANGING_CORE__AMBIENT_WINDOW_EVENTS_1_LLM = 0x098C,
|
||
|
RANGING_CORE__AMBIENT_WINDOW_EVENTS_1_LLL = 0x098D,
|
||
|
RANGING_CORE__RANGING_TOTAL_EVENTS_1_MMM = 0x098E,
|
||
|
RANGING_CORE__RANGING_TOTAL_EVENTS_1_LMM = 0x098F,
|
||
|
RANGING_CORE__RANGING_TOTAL_EVENTS_1_LLM = 0x0990,
|
||
|
RANGING_CORE__RANGING_TOTAL_EVENTS_1_LLL = 0x0991,
|
||
|
RANGING_CORE__SIGNAL_TOTAL_EVENTS_1_MMM = 0x0992,
|
||
|
RANGING_CORE__SIGNAL_TOTAL_EVENTS_1_LMM = 0x0993,
|
||
|
RANGING_CORE__SIGNAL_TOTAL_EVENTS_1_LLM = 0x0994,
|
||
|
RANGING_CORE__SIGNAL_TOTAL_EVENTS_1_LLL = 0x0995,
|
||
|
RANGING_CORE__TOTAL_PERIODS_ELAPSED_1_MM = 0x0996,
|
||
|
RANGING_CORE__TOTAL_PERIODS_ELAPSED_1_LM = 0x0997,
|
||
|
RANGING_CORE__TOTAL_PERIODS_ELAPSED_1_LL = 0x0998,
|
||
|
RANGING_CORE__AMBIENT_MISMATCH_MM = 0x0999,
|
||
|
RANGING_CORE__AMBIENT_MISMATCH_LM = 0x099A,
|
||
|
RANGING_CORE__AMBIENT_MISMATCH_LL = 0x099B,
|
||
|
RANGING_CORE__AMBIENT_WINDOW_EVENTS_REF_1_MMM = 0x099C,
|
||
|
RANGING_CORE__AMBIENT_WINDOW_EVENTS_REF_1_LMM = 0x099D,
|
||
|
RANGING_CORE__AMBIENT_WINDOW_EVENTS_REF_1_LLM = 0x099E,
|
||
|
RANGING_CORE__AMBIENT_WINDOW_EVENTS_REF_1_LLL = 0x099F,
|
||
|
RANGING_CORE__RANGING_TOTAL_EVENTS_REF_1_MMM = 0x09A0,
|
||
|
RANGING_CORE__RANGING_TOTAL_EVENTS_REF_1_LMM = 0x09A1,
|
||
|
RANGING_CORE__RANGING_TOTAL_EVENTS_REF_1_LLM = 0x09A2,
|
||
|
RANGING_CORE__RANGING_TOTAL_EVENTS_REF_1_LLL = 0x09A3,
|
||
|
RANGING_CORE__SIGNAL_TOTAL_EVENTS_REF_1_MMM = 0x09A4,
|
||
|
RANGING_CORE__SIGNAL_TOTAL_EVENTS_REF_1_LMM = 0x09A5,
|
||
|
RANGING_CORE__SIGNAL_TOTAL_EVENTS_REF_1_LLM = 0x09A6,
|
||
|
RANGING_CORE__SIGNAL_TOTAL_EVENTS_REF_1_LLL = 0x09A7,
|
||
|
RANGING_CORE__TOTAL_PERIODS_ELAPSED_REF_1_MM = 0x09A8,
|
||
|
RANGING_CORE__TOTAL_PERIODS_ELAPSED_REF_1_LM = 0x09A9,
|
||
|
RANGING_CORE__TOTAL_PERIODS_ELAPSED_REF_1_LL = 0x09AA,
|
||
|
RANGING_CORE__AMBIENT_MISMATCH_REF_MM = 0x09AB,
|
||
|
RANGING_CORE__AMBIENT_MISMATCH_REF_LM = 0x09AC,
|
||
|
RANGING_CORE__AMBIENT_MISMATCH_REF_LL = 0x09AD,
|
||
|
RANGING_CORE__GPIO_CONFIG__A0 = 0x0A00,
|
||
|
RANGING_CORE__RESET_CONTROL__A0 = 0x0A01,
|
||
|
RANGING_CORE__INTR_MANAGER__A0 = 0x0A02,
|
||
|
RANGING_CORE__POWER_FSM_TIME_OSC__A0 = 0x0A06,
|
||
|
RANGING_CORE__VCSEL_ATEST__A0 = 0x0A07,
|
||
|
RANGING_CORE__VCSEL_PERIOD_CLIPPED__A0 = 0x0A08,
|
||
|
RANGING_CORE__VCSEL_STOP_CLIPPED__A0 = 0x0A09,
|
||
|
RANGING_CORE__CALIB_2__A0 = 0x0A0A,
|
||
|
RANGING_CORE__STOP_CONDITION__A0 = 0x0A0B,
|
||
|
RANGING_CORE__STATUS_RESET__A0 = 0x0A0C,
|
||
|
RANGING_CORE__READOUT_CFG__A0 = 0x0A0D,
|
||
|
RANGING_CORE__WINDOW_SETTING__A0 = 0x0A0E,
|
||
|
RANGING_CORE__VCSEL_DELAY__A0 = 0x0A1A,
|
||
|
RANGING_CORE__REFERENCE_2__A0 = 0x0A1B,
|
||
|
RANGING_CORE__REGAVDD1V2__A0 = 0x0A1D,
|
||
|
RANGING_CORE__TST_MUX__A0 = 0x0A1F,
|
||
|
RANGING_CORE__CUSTOM_FE_2__A0 = 0x0A20,
|
||
|
RANGING_CORE__SPAD_READOUT__A0 = 0x0A21,
|
||
|
RANGING_CORE__CPUMP_1__A0 = 0x0A22,
|
||
|
RANGING_CORE__SPARE_REGISTER__A0 = 0x0A23,
|
||
|
RANGING_CORE__VCSEL_CONT_STAGE5_BYPASS__A0 = 0x0A24,
|
||
|
RANGING_CORE__RET_SPAD_EN_18 = 0x0A25,
|
||
|
RANGING_CORE__RET_SPAD_EN_19 = 0x0A26,
|
||
|
RANGING_CORE__RET_SPAD_EN_20 = 0x0A27,
|
||
|
RANGING_CORE__RET_SPAD_EN_21 = 0x0A28,
|
||
|
RANGING_CORE__RET_SPAD_EN_22 = 0x0A29,
|
||
|
RANGING_CORE__RET_SPAD_EN_23 = 0x0A2A,
|
||
|
RANGING_CORE__RET_SPAD_EN_24 = 0x0A2B,
|
||
|
RANGING_CORE__RET_SPAD_EN_25 = 0x0A2C,
|
||
|
RANGING_CORE__RET_SPAD_EN_26 = 0x0A2D,
|
||
|
RANGING_CORE__RET_SPAD_EN_27 = 0x0A2E,
|
||
|
RANGING_CORE__RET_SPAD_EN_28 = 0x0A2F,
|
||
|
RANGING_CORE__RET_SPAD_EN_29 = 0x0A30,
|
||
|
RANGING_CORE__RET_SPAD_EN_30 = 0x0A31,
|
||
|
RANGING_CORE__RET_SPAD_EN_31 = 0x0A32,
|
||
|
RANGING_CORE__REF_SPAD_EN_0__EWOK = 0x0A33,
|
||
|
RANGING_CORE__REF_SPAD_EN_1__EWOK = 0x0A34,
|
||
|
RANGING_CORE__REF_SPAD_EN_2__EWOK = 0x0A35,
|
||
|
RANGING_CORE__REF_SPAD_EN_3__EWOK = 0x0A36,
|
||
|
RANGING_CORE__REF_SPAD_EN_4__EWOK = 0x0A37,
|
||
|
RANGING_CORE__REF_SPAD_EN_5__EWOK = 0x0A38,
|
||
|
RANGING_CORE__REF_EN_START_SELECT = 0x0A39,
|
||
|
RANGING_CORE__REGDVDD1V2_ATEST__EWOK = 0x0A41,
|
||
|
SOFT_RESET_GO1 = 0x0B00,
|
||
|
PRIVATE__PATCH_BASE_ADDR_RSLV = 0x0E00,
|
||
|
PREV_SHADOW_RESULT__INTERRUPT_STATUS = 0x0ED0,
|
||
|
PREV_SHADOW_RESULT__RANGE_STATUS = 0x0ED1,
|
||
|
PREV_SHADOW_RESULT__REPORT_STATUS = 0x0ED2,
|
||
|
PREV_SHADOW_RESULT__STREAM_COUNT = 0x0ED3,
|
||
|
PREV_SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0 = 0x0ED4,
|
||
|
PREV_SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0_HI = 0x0ED4,
|
||
|
PREV_SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0_LO = 0x0ED5,
|
||
|
PREV_SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD0 = 0x0ED6,
|
||
|
PREV_SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD0_HI = 0x0ED6,
|
||
|
PREV_SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD0_LO = 0x0ED7,
|
||
|
PREV_SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD0 = 0x0ED8,
|
||
|
PREV_SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD0_HI = 0x0ED8,
|
||
|
PREV_SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD0_LO = 0x0ED9,
|
||
|
PREV_SHADOW_RESULT__SIGMA_SD0 = 0x0EDA,
|
||
|
PREV_SHADOW_RESULT__SIGMA_SD0_HI = 0x0EDA,
|
||
|
PREV_SHADOW_RESULT__SIGMA_SD0_LO = 0x0EDB,
|
||
|
PREV_SHADOW_RESULT__PHASE_SD0 = 0x0EDC,
|
||
|
PREV_SHADOW_RESULT__PHASE_SD0_HI = 0x0EDC,
|
||
|
PREV_SHADOW_RESULT__PHASE_SD0_LO = 0x0EDD,
|
||
|
PREV_SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0 = 0x0EDE,
|
||
|
PREV_SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0_HI = 0x0EDE,
|
||
|
PREV_SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0_LO = 0x0EDF,
|
||
|
PREV_SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0 = 0x0EE0,
|
||
|
PREV_SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0_HI = 0x0EE0,
|
||
|
PREV_SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0_LO = 0x0EE1,
|
||
|
PREV_SHADOW_RESULT__MM_INNER_ACTUAL_EFFECTIVE_SPADS_SD0 = 0x0EE2,
|
||
|
PREV_SHADOW_RESULT__MM_INNER_ACTUAL_EFFECTIVE_SPADS_SD0_HI = 0x0EE2,
|
||
|
PREV_SHADOW_RESULT__MM_INNER_ACTUAL_EFFECTIVE_SPADS_SD0_LO = 0x0EE3,
|
||
|
PREV_SHADOW_RESULT__MM_OUTER_ACTUAL_EFFECTIVE_SPADS_SD0 = 0x0EE4,
|
||
|
PREV_SHADOW_RESULT__MM_OUTER_ACTUAL_EFFECTIVE_SPADS_SD0_HI = 0x0EE4,
|
||
|
PREV_SHADOW_RESULT__MM_OUTER_ACTUAL_EFFECTIVE_SPADS_SD0_LO = 0x0EE5,
|
||
|
PREV_SHADOW_RESULT__AVG_SIGNAL_COUNT_RATE_MCPS_SD0 = 0x0EE6,
|
||
|
PREV_SHADOW_RESULT__AVG_SIGNAL_COUNT_RATE_MCPS_SD0_HI = 0x0EE6,
|
||
|
PREV_SHADOW_RESULT__AVG_SIGNAL_COUNT_RATE_MCPS_SD0_LO = 0x0EE7,
|
||
|
PREV_SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD1 = 0x0EE8,
|
||
|
PREV_SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD1_HI = 0x0EE8,
|
||
|
PREV_SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD1_LO = 0x0EE9,
|
||
|
PREV_SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD1 = 0x0EEA,
|
||
|
PREV_SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD1_HI = 0x0EEA,
|
||
|
PREV_SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD1_LO = 0x0EEB,
|
||
|
PREV_SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD1 = 0x0EEC,
|
||
|
PREV_SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD1_HI = 0x0EEC,
|
||
|
PREV_SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD1_LO = 0x0EED,
|
||
|
PREV_SHADOW_RESULT__SIGMA_SD1 = 0x0EEE,
|
||
|
PREV_SHADOW_RESULT__SIGMA_SD1_HI = 0x0EEE,
|
||
|
PREV_SHADOW_RESULT__SIGMA_SD1_LO = 0x0EEF,
|
||
|
PREV_SHADOW_RESULT__PHASE_SD1 = 0x0EF0,
|
||
|
PREV_SHADOW_RESULT__PHASE_SD1_HI = 0x0EF0,
|
||
|
PREV_SHADOW_RESULT__PHASE_SD1_LO = 0x0EF1,
|
||
|
PREV_SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD1 = 0x0EF2,
|
||
|
PREV_SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD1_HI = 0x0EF2,
|
||
|
PREV_SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD1_LO = 0x0EF3,
|
||
|
PREV_SHADOW_RESULT__SPARE_0_SD1 = 0x0EF4,
|
||
|
PREV_SHADOW_RESULT__SPARE_0_SD1_HI = 0x0EF4,
|
||
|
PREV_SHADOW_RESULT__SPARE_0_SD1_LO = 0x0EF5,
|
||
|
PREV_SHADOW_RESULT__SPARE_1_SD1 = 0x0EF6,
|
||
|
PREV_SHADOW_RESULT__SPARE_1_SD1_HI = 0x0EF6,
|
||
|
PREV_SHADOW_RESULT__SPARE_1_SD1_LO = 0x0EF7,
|
||
|
PREV_SHADOW_RESULT__SPARE_2_SD1 = 0x0EF8,
|
||
|
PREV_SHADOW_RESULT__SPARE_2_SD1_HI = 0x0EF8,
|
||
|
PREV_SHADOW_RESULT__SPARE_2_SD1_LO = 0x0EF9,
|
||
|
PREV_SHADOW_RESULT__SPARE_3_SD1 = 0x0EFA,
|
||
|
PREV_SHADOW_RESULT__SPARE_3_SD1_HI = 0x0EFA,
|
||
|
PREV_SHADOW_RESULT__SPARE_3_SD1_LO = 0x0EFB,
|
||
|
PREV_SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0 = 0x0EFC,
|
||
|
PREV_SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_3 = 0x0EFC,
|
||
|
PREV_SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_2 = 0x0EFD,
|
||
|
PREV_SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_1 = 0x0EFE,
|
||
|
PREV_SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_0 = 0x0EFF,
|
||
|
PREV_SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD0 = 0x0F00,
|
||
|
PREV_SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_3 = 0x0F00,
|
||
|
PREV_SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_2 = 0x0F01,
|
||
|
PREV_SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_1 = 0x0F02,
|
||
|
PREV_SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_0 = 0x0F03,
|
||
|
PREV_SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0 = 0x0F04,
|
||
|
PREV_SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_3 = 0x0F04,
|
||
|
PREV_SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_2 = 0x0F05,
|
||
|
PREV_SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_1 = 0x0F06,
|
||
|
PREV_SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_0 = 0x0F07,
|
||
|
PREV_SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0 = 0x0F08,
|
||
|
PREV_SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_3 = 0x0F08,
|
||
|
PREV_SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_2 = 0x0F09,
|
||
|
PREV_SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_1 = 0x0F0A,
|
||
|
PREV_SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_0 = 0x0F0B,
|
||
|
PREV_SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1 = 0x0F0C,
|
||
|
PREV_SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_3 = 0x0F0C,
|
||
|
PREV_SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_2 = 0x0F0D,
|
||
|
PREV_SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_1 = 0x0F0E,
|
||
|
PREV_SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_0 = 0x0F0F,
|
||
|
PREV_SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD1 = 0x0F10,
|
||
|
PREV_SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_3 = 0x0F10,
|
||
|
PREV_SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_2 = 0x0F11,
|
||
|
PREV_SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_1 = 0x0F12,
|
||
|
PREV_SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_0 = 0x0F13,
|
||
|
PREV_SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1 = 0x0F14,
|
||
|
PREV_SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_3 = 0x0F14,
|
||
|
PREV_SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_2 = 0x0F15,
|
||
|
PREV_SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_1 = 0x0F16,
|
||
|
PREV_SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_0 = 0x0F17,
|
||
|
PREV_SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1 = 0x0F18,
|
||
|
PREV_SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_3 = 0x0F18,
|
||
|
PREV_SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_2 = 0x0F19,
|
||
|
PREV_SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_1 = 0x0F1A,
|
||
|
PREV_SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_0 = 0x0F1B,
|
||
|
PREV_SHADOW_RESULT_CORE__SPARE_0 = 0x0F1C,
|
||
|
RESULT__DEBUG_STATUS = 0x0F20,
|
||
|
RESULT__DEBUG_STAGE = 0x0F21,
|
||
|
GPH__SYSTEM__THRESH_RATE_HIGH = 0x0F24,
|
||
|
GPH__SYSTEM__THRESH_RATE_HIGH_HI = 0x0F24,
|
||
|
GPH__SYSTEM__THRESH_RATE_HIGH_LO = 0x0F25,
|
||
|
GPH__SYSTEM__THRESH_RATE_LOW = 0x0F26,
|
||
|
GPH__SYSTEM__THRESH_RATE_LOW_HI = 0x0F26,
|
||
|
GPH__SYSTEM__THRESH_RATE_LOW_LO = 0x0F27,
|
||
|
GPH__SYSTEM__INTERRUPT_CONFIG_GPIO = 0x0F28,
|
||
|
GPH__DSS_CONFIG__ROI_MODE_CONTROL = 0x0F2F,
|
||
|
GPH__DSS_CONFIG__MANUAL_EFFECTIVE_SPADS_SELECT = 0x0F30,
|
||
|
GPH__DSS_CONFIG__MANUAL_EFFECTIVE_SPADS_SELECT_HI = 0x0F30,
|
||
|
GPH__DSS_CONFIG__MANUAL_EFFECTIVE_SPADS_SELECT_LO = 0x0F31,
|
||
|
GPH__DSS_CONFIG__MANUAL_BLOCK_SELECT = 0x0F32,
|
||
|
GPH__DSS_CONFIG__MAX_SPADS_LIMIT = 0x0F33,
|
||
|
GPH__DSS_CONFIG__MIN_SPADS_LIMIT = 0x0F34,
|
||
|
GPH__MM_CONFIG__TIMEOUT_MACROP_A_HI = 0x0F36,
|
||
|
GPH__MM_CONFIG__TIMEOUT_MACROP_A_LO = 0x0F37,
|
||
|
GPH__MM_CONFIG__TIMEOUT_MACROP_B_HI = 0x0F38,
|
||
|
GPH__MM_CONFIG__TIMEOUT_MACROP_B_LO = 0x0F39,
|
||
|
GPH__RANGE_CONFIG__TIMEOUT_MACROP_A_HI = 0x0F3A,
|
||
|
GPH__RANGE_CONFIG__TIMEOUT_MACROP_A_LO = 0x0F3B,
|
||
|
GPH__RANGE_CONFIG__VCSEL_PERIOD_A = 0x0F3C,
|
||
|
GPH__RANGE_CONFIG__VCSEL_PERIOD_B = 0x0F3D,
|
||
|
GPH__RANGE_CONFIG__TIMEOUT_MACROP_B_HI = 0x0F3E,
|
||
|
GPH__RANGE_CONFIG__TIMEOUT_MACROP_B_LO = 0x0F3F,
|
||
|
GPH__RANGE_CONFIG__SIGMA_THRESH = 0x0F40,
|
||
|
GPH__RANGE_CONFIG__SIGMA_THRESH_HI = 0x0F40,
|
||
|
GPH__RANGE_CONFIG__SIGMA_THRESH_LO = 0x0F41,
|
||
|
GPH__RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS = 0x0F42,
|
||
|
GPH__RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS_HI = 0x0F42,
|
||
|
GPH__RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS_LO = 0x0F43,
|
||
|
GPH__RANGE_CONFIG__VALID_PHASE_LOW = 0x0F44,
|
||
|
GPH__RANGE_CONFIG__VALID_PHASE_HIGH = 0x0F45,
|
||
|
FIRMWARE__INTERNAL_STREAM_COUNT_DIV = 0x0F46,
|
||
|
FIRMWARE__INTERNAL_STREAM_COUNTER_VAL = 0x0F47,
|
||
|
DSS_CALC__ROI_CTRL = 0x0F54,
|
||
|
DSS_CALC__SPARE_1 = 0x0F55,
|
||
|
DSS_CALC__SPARE_2 = 0x0F56,
|
||
|
DSS_CALC__SPARE_3 = 0x0F57,
|
||
|
DSS_CALC__SPARE_4 = 0x0F58,
|
||
|
DSS_CALC__SPARE_5 = 0x0F59,
|
||
|
DSS_CALC__SPARE_6 = 0x0F5A,
|
||
|
DSS_CALC__SPARE_7 = 0x0F5B,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_0 = 0x0F5C,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_1 = 0x0F5D,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_2 = 0x0F5E,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_3 = 0x0F5F,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_4 = 0x0F60,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_5 = 0x0F61,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_6 = 0x0F62,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_7 = 0x0F63,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_8 = 0x0F64,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_9 = 0x0F65,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_10 = 0x0F66,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_11 = 0x0F67,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_12 = 0x0F68,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_13 = 0x0F69,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_14 = 0x0F6A,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_15 = 0x0F6B,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_16 = 0x0F6C,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_17 = 0x0F6D,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_18 = 0x0F6E,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_19 = 0x0F6F,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_20 = 0x0F70,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_21 = 0x0F71,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_22 = 0x0F72,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_23 = 0x0F73,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_24 = 0x0F74,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_25 = 0x0F75,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_26 = 0x0F76,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_27 = 0x0F77,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_28 = 0x0F78,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_29 = 0x0F79,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_30 = 0x0F7A,
|
||
|
DSS_CALC__USER_ROI_SPAD_EN_31 = 0x0F7B,
|
||
|
DSS_CALC__USER_ROI_0 = 0x0F7C,
|
||
|
DSS_CALC__USER_ROI_1 = 0x0F7D,
|
||
|
DSS_CALC__MODE_ROI_0 = 0x0F7E,
|
||
|
DSS_CALC__MODE_ROI_1 = 0x0F7F,
|
||
|
SIGMA_ESTIMATOR_CALC__SPARE_0 = 0x0F80,
|
||
|
VHV_RESULT__PEAK_SIGNAL_RATE_MCPS = 0x0F82,
|
||
|
VHV_RESULT__PEAK_SIGNAL_RATE_MCPS_HI = 0x0F82,
|
||
|
VHV_RESULT__PEAK_SIGNAL_RATE_MCPS_LO = 0x0F83,
|
||
|
VHV_RESULT__SIGNAL_TOTAL_EVENTS_REF = 0x0F84,
|
||
|
VHV_RESULT__SIGNAL_TOTAL_EVENTS_REF_3 = 0x0F84,
|
||
|
VHV_RESULT__SIGNAL_TOTAL_EVENTS_REF_2 = 0x0F85,
|
||
|
VHV_RESULT__SIGNAL_TOTAL_EVENTS_REF_1 = 0x0F86,
|
||
|
VHV_RESULT__SIGNAL_TOTAL_EVENTS_REF_0 = 0x0F87,
|
||
|
PHASECAL_RESULT__PHASE_OUTPUT_REF = 0x0F88,
|
||
|
PHASECAL_RESULT__PHASE_OUTPUT_REF_HI = 0x0F88,
|
||
|
PHASECAL_RESULT__PHASE_OUTPUT_REF_LO = 0x0F89,
|
||
|
DSS_RESULT__TOTAL_RATE_PER_SPAD = 0x0F8A,
|
||
|
DSS_RESULT__TOTAL_RATE_PER_SPAD_HI = 0x0F8A,
|
||
|
DSS_RESULT__TOTAL_RATE_PER_SPAD_LO = 0x0F8B,
|
||
|
DSS_RESULT__ENABLED_BLOCKS = 0x0F8C,
|
||
|
DSS_RESULT__NUM_REQUESTED_SPADS = 0x0F8E,
|
||
|
DSS_RESULT__NUM_REQUESTED_SPADS_HI = 0x0F8E,
|
||
|
DSS_RESULT__NUM_REQUESTED_SPADS_LO = 0x0F8F,
|
||
|
MM_RESULT__INNER_INTERSECTION_RATE = 0x0F92,
|
||
|
MM_RESULT__INNER_INTERSECTION_RATE_HI = 0x0F92,
|
||
|
MM_RESULT__INNER_INTERSECTION_RATE_LO = 0x0F93,
|
||
|
MM_RESULT__OUTER_COMPLEMENT_RATE = 0x0F94,
|
||
|
MM_RESULT__OUTER_COMPLEMENT_RATE_HI = 0x0F94,
|
||
|
MM_RESULT__OUTER_COMPLEMENT_RATE_LO = 0x0F95,
|
||
|
MM_RESULT__TOTAL_OFFSET = 0x0F96,
|
||
|
MM_RESULT__TOTAL_OFFSET_HI = 0x0F96,
|
||
|
MM_RESULT__TOTAL_OFFSET_LO = 0x0F97,
|
||
|
XTALK_CALC__XTALK_FOR_ENABLED_SPADS = 0x0F98,
|
||
|
XTALK_CALC__XTALK_FOR_ENABLED_SPADS_3 = 0x0F98,
|
||
|
XTALK_CALC__XTALK_FOR_ENABLED_SPADS_2 = 0x0F99,
|
||
|
XTALK_CALC__XTALK_FOR_ENABLED_SPADS_1 = 0x0F9A,
|
||
|
XTALK_CALC__XTALK_FOR_ENABLED_SPADS_0 = 0x0F9B,
|
||
|
XTALK_RESULT__AVG_XTALK_USER_ROI_KCPS = 0x0F9C,
|
||
|
XTALK_RESULT__AVG_XTALK_USER_ROI_KCPS_3 = 0x0F9C,
|
||
|
XTALK_RESULT__AVG_XTALK_USER_ROI_KCPS_2 = 0x0F9D,
|
||
|
XTALK_RESULT__AVG_XTALK_USER_ROI_KCPS_1 = 0x0F9E,
|
||
|
XTALK_RESULT__AVG_XTALK_USER_ROI_KCPS_0 = 0x0F9F,
|
||
|
XTALK_RESULT__AVG_XTALK_MM_INNER_ROI_KCPS = 0x0FA0,
|
||
|
XTALK_RESULT__AVG_XTALK_MM_INNER_ROI_KCPS_3 = 0x0FA0,
|
||
|
XTALK_RESULT__AVG_XTALK_MM_INNER_ROI_KCPS_2 = 0x0FA1,
|
||
|
XTALK_RESULT__AVG_XTALK_MM_INNER_ROI_KCPS_1 = 0x0FA2,
|
||
|
XTALK_RESULT__AVG_XTALK_MM_INNER_ROI_KCPS_0 = 0x0FA3,
|
||
|
XTALK_RESULT__AVG_XTALK_MM_OUTER_ROI_KCPS = 0x0FA4,
|
||
|
XTALK_RESULT__AVG_XTALK_MM_OUTER_ROI_KCPS_3 = 0x0FA4,
|
||
|
XTALK_RESULT__AVG_XTALK_MM_OUTER_ROI_KCPS_2 = 0x0FA5,
|
||
|
XTALK_RESULT__AVG_XTALK_MM_OUTER_ROI_KCPS_1 = 0x0FA6,
|
||
|
XTALK_RESULT__AVG_XTALK_MM_OUTER_ROI_KCPS_0 = 0x0FA7,
|
||
|
RANGE_RESULT__ACCUM_PHASE = 0x0FA8,
|
||
|
RANGE_RESULT__ACCUM_PHASE_3 = 0x0FA8,
|
||
|
RANGE_RESULT__ACCUM_PHASE_2 = 0x0FA9,
|
||
|
RANGE_RESULT__ACCUM_PHASE_1 = 0x0FAA,
|
||
|
RANGE_RESULT__ACCUM_PHASE_0 = 0x0FAB,
|
||
|
RANGE_RESULT__OFFSET_CORRECTED_RANGE = 0x0FAC,
|
||
|
RANGE_RESULT__OFFSET_CORRECTED_RANGE_HI = 0x0FAC,
|
||
|
RANGE_RESULT__OFFSET_CORRECTED_RANGE_LO = 0x0FAD,
|
||
|
SHADOW_PHASECAL_RESULT__VCSEL_START = 0x0FAE,
|
||
|
SHADOW_RESULT__INTERRUPT_STATUS = 0x0FB0,
|
||
|
SHADOW_RESULT__RANGE_STATUS = 0x0FB1,
|
||
|
SHADOW_RESULT__REPORT_STATUS = 0x0FB2,
|
||
|
SHADOW_RESULT__STREAM_COUNT = 0x0FB3,
|
||
|
SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0 = 0x0FB4,
|
||
|
SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0_HI = 0x0FB4,
|
||
|
SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0_LO = 0x0FB5,
|
||
|
SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD0 = 0x0FB6,
|
||
|
SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD0_HI = 0x0FB6,
|
||
|
SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD0_LO = 0x0FB7,
|
||
|
SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD0 = 0x0FB8,
|
||
|
SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD0_HI = 0x0FB8,
|
||
|
SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD0_LO = 0x0FB9,
|
||
|
SHADOW_RESULT__SIGMA_SD0 = 0x0FBA,
|
||
|
SHADOW_RESULT__SIGMA_SD0_HI = 0x0FBA,
|
||
|
SHADOW_RESULT__SIGMA_SD0_LO = 0x0FBB,
|
||
|
SHADOW_RESULT__PHASE_SD0 = 0x0FBC,
|
||
|
SHADOW_RESULT__PHASE_SD0_HI = 0x0FBC,
|
||
|
SHADOW_RESULT__PHASE_SD0_LO = 0x0FBD,
|
||
|
SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0 = 0x0FBE,
|
||
|
SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0_HI = 0x0FBE,
|
||
|
SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0_LO = 0x0FBF,
|
||
|
SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0 = 0x0FC0,
|
||
|
SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0_HI = 0x0FC0,
|
||
|
SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0_LO = 0x0FC1,
|
||
|
SHADOW_RESULT__MM_INNER_ACTUAL_EFFECTIVE_SPADS_SD0 = 0x0FC2,
|
||
|
SHADOW_RESULT__MM_INNER_ACTUAL_EFFECTIVE_SPADS_SD0_HI = 0x0FC2,
|
||
|
SHADOW_RESULT__MM_INNER_ACTUAL_EFFECTIVE_SPADS_SD0_LO = 0x0FC3,
|
||
|
SHADOW_RESULT__MM_OUTER_ACTUAL_EFFECTIVE_SPADS_SD0 = 0x0FC4,
|
||
|
SHADOW_RESULT__MM_OUTER_ACTUAL_EFFECTIVE_SPADS_SD0_HI = 0x0FC4,
|
||
|
SHADOW_RESULT__MM_OUTER_ACTUAL_EFFECTIVE_SPADS_SD0_LO = 0x0FC5,
|
||
|
SHADOW_RESULT__AVG_SIGNAL_COUNT_RATE_MCPS_SD0 = 0x0FC6,
|
||
|
SHADOW_RESULT__AVG_SIGNAL_COUNT_RATE_MCPS_SD0_HI = 0x0FC6,
|
||
|
SHADOW_RESULT__AVG_SIGNAL_COUNT_RATE_MCPS_SD0_LO = 0x0FC7,
|
||
|
SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD1 = 0x0FC8,
|
||
|
SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD1_HI = 0x0FC8,
|
||
|
SHADOW_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD1_LO = 0x0FC9,
|
||
|
SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD1 = 0x0FCA,
|
||
|
SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD1_HI = 0x0FCA,
|
||
|
SHADOW_RESULT__PEAK_SIGNAL_COUNT_RATE_MCPS_SD1_LO = 0x0FCB,
|
||
|
SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD1 = 0x0FCC,
|
||
|
SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD1_HI = 0x0FCC,
|
||
|
SHADOW_RESULT__AMBIENT_COUNT_RATE_MCPS_SD1_LO = 0x0FCD,
|
||
|
SHADOW_RESULT__SIGMA_SD1 = 0x0FCE,
|
||
|
SHADOW_RESULT__SIGMA_SD1_HI = 0x0FCE,
|
||
|
SHADOW_RESULT__SIGMA_SD1_LO = 0x0FCF,
|
||
|
SHADOW_RESULT__PHASE_SD1 = 0x0FD0,
|
||
|
SHADOW_RESULT__PHASE_SD1_HI = 0x0FD0,
|
||
|
SHADOW_RESULT__PHASE_SD1_LO = 0x0FD1,
|
||
|
SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD1 = 0x0FD2,
|
||
|
SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD1_HI = 0x0FD2,
|
||
|
SHADOW_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD1_LO = 0x0FD3,
|
||
|
SHADOW_RESULT__SPARE_0_SD1 = 0x0FD4,
|
||
|
SHADOW_RESULT__SPARE_0_SD1_HI = 0x0FD4,
|
||
|
SHADOW_RESULT__SPARE_0_SD1_LO = 0x0FD5,
|
||
|
SHADOW_RESULT__SPARE_1_SD1 = 0x0FD6,
|
||
|
SHADOW_RESULT__SPARE_1_SD1_HI = 0x0FD6,
|
||
|
SHADOW_RESULT__SPARE_1_SD1_LO = 0x0FD7,
|
||
|
SHADOW_RESULT__SPARE_2_SD1 = 0x0FD8,
|
||
|
SHADOW_RESULT__SPARE_2_SD1_HI = 0x0FD8,
|
||
|
SHADOW_RESULT__SPARE_2_SD1_LO = 0x0FD9,
|
||
|
SHADOW_RESULT__SPARE_3_SD1 = 0x0FDA,
|
||
|
SHADOW_RESULT__THRESH_INFO = 0x0FDB,
|
||
|
SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0 = 0x0FDC,
|
||
|
SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_3 = 0x0FDC,
|
||
|
SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_2 = 0x0FDD,
|
||
|
SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_1 = 0x0FDE,
|
||
|
SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD0_0 = 0x0FDF,
|
||
|
SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD0 = 0x0FE0,
|
||
|
SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_3 = 0x0FE0,
|
||
|
SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_2 = 0x0FE1,
|
||
|
SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_1 = 0x0FE2,
|
||
|
SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD0_0 = 0x0FE3,
|
||
|
SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0 = 0x0FE4,
|
||
|
SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_3 = 0x0FE4,
|
||
|
SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_2 = 0x0FE5,
|
||
|
SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_1 = 0x0FE6,
|
||
|
SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD0_0 = 0x0FE7,
|
||
|
SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0 = 0x0FE8,
|
||
|
SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_3 = 0x0FE8,
|
||
|
SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_2 = 0x0FE9,
|
||
|
SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_1 = 0x0FEA,
|
||
|
SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD0_0 = 0x0FEB,
|
||
|
SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1 = 0x0FEC,
|
||
|
SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_3 = 0x0FEC,
|
||
|
SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_2 = 0x0FED,
|
||
|
SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_1 = 0x0FEE,
|
||
|
SHADOW_RESULT_CORE__AMBIENT_WINDOW_EVENTS_SD1_0 = 0x0FEF,
|
||
|
SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD1 = 0x0FF0,
|
||
|
SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_3 = 0x0FF0,
|
||
|
SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_2 = 0x0FF1,
|
||
|
SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_1 = 0x0FF2,
|
||
|
SHADOW_RESULT_CORE__RANGING_TOTAL_EVENTS_SD1_0 = 0x0FF3,
|
||
|
SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1 = 0x0FF4,
|
||
|
SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_3 = 0x0FF4,
|
||
|
SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_2 = 0x0FF5,
|
||
|
SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_1 = 0x0FF6,
|
||
|
SHADOW_RESULT_CORE__SIGNAL_TOTAL_EVENTS_SD1_0 = 0x0FF7,
|
||
|
SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1 = 0x0FF8,
|
||
|
SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_3 = 0x0FF8,
|
||
|
SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_2 = 0x0FF9,
|
||
|
SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_1 = 0x0FFA,
|
||
|
SHADOW_RESULT_CORE__TOTAL_PERIODS_ELAPSED_SD1_0 = 0x0FFB,
|
||
|
SHADOW_RESULT_CORE__SPARE_0 = 0x0FFC,
|
||
|
SHADOW_PHASECAL_RESULT__REFERENCE_PHASE_HI = 0x0FFE,
|
||
|
SHADOW_PHASECAL_RESULT__REFERENCE_PHASE_LO = 0x0FFF,
|
||
|
};
|
||
|
|
||
|
enum DistanceMode { Short, Medium, Long, Unknown };
|
||
|
|
||
|
enum RangeStatus : uint8_t
|
||
|
{
|
||
|
RangeValid = 0,
|
||
|
|
||
|
// "sigma estimator check is above the internal defined threshold"
|
||
|
// (sigma = standard deviation of measurement)
|
||
|
SigmaFail = 1,
|
||
|
|
||
|
// "signal value is below the internal defined threshold"
|
||
|
SignalFail = 2,
|
||
|
|
||
|
// "Target is below minimum detection threshold."
|
||
|
RangeValidMinRangeClipped = 3,
|
||
|
|
||
|
// "phase is out of bounds"
|
||
|
// (nothing detected in range; try a longer distance mode if applicable)
|
||
|
OutOfBoundsFail = 4,
|
||
|
|
||
|
// "HW or VCSEL failure"
|
||
|
HardwareFail = 5,
|
||
|
|
||
|
// "The Range is valid but the wraparound check has not been done."
|
||
|
RangeValidNoWrapCheckFail = 6,
|
||
|
|
||
|
// "Wrapped target, not matching phases"
|
||
|
// "no matching phase in other VCSEL period timing."
|
||
|
WrapTargetFail = 7,
|
||
|
|
||
|
// "Internal algo underflow or overflow in lite ranging."
|
||
|
// ProcessingFail = 8: not used in API
|
||
|
|
||
|
// "Specific to lite ranging."
|
||
|
// should never occur with this lib (which uses low power auto ranging,
|
||
|
// as the API does)
|
||
|
XtalkSignalFail = 9,
|
||
|
|
||
|
// "1st interrupt when starting ranging in back to back mode. Ignore
|
||
|
// data."
|
||
|
// should never occur with this lib
|
||
|
SynchronizationInt = 10, // (the API spells this "syncronisation")
|
||
|
|
||
|
// "All Range ok but object is result of multiple pulses merging together.
|
||
|
// Used by RQL for merged pulse detection"
|
||
|
// RangeValid MergedPulse = 11: not used in API
|
||
|
|
||
|
// "Used by RQL as different to phase fail."
|
||
|
// TargetPresentLackOfSignal = 12:
|
||
|
|
||
|
// "Target is below minimum detection threshold."
|
||
|
MinRangeFail = 13,
|
||
|
|
||
|
// "The reported range is invalid"
|
||
|
// RangeInvalid = 14: can't actually be returned by API (range can never become negative, even after correction)
|
||
|
|
||
|
// "No Update."
|
||
|
None = 255,
|
||
|
};
|
||
|
|
||
|
struct RangingData
|
||
|
{
|
||
|
uint16_t range_mm;
|
||
|
RangeStatus range_status;
|
||
|
float peak_signal_count_rate_MCPS;
|
||
|
float ambient_count_rate_MCPS;
|
||
|
};
|
||
|
|
||
|
RangingData ranging_data;
|
||
|
|
||
|
uint8_t last_status; // status of last I2C transmission
|
||
|
|
||
|
public:
|
||
|
VL53L1X() {}
|
||
|
|
||
|
uint16_t getid();
|
||
|
uint16_t getosc();
|
||
|
void setosc(uint16_t value);
|
||
|
|
||
|
void setAddress(uint8_t new_addr);
|
||
|
uint8_t getAddress() { return address; }
|
||
|
|
||
|
bool init(bool io_2v8 = true);
|
||
|
|
||
|
void writeReg(uint16_t reg, uint8_t value);
|
||
|
void writeReg16Bit(uint16_t reg, uint16_t value);
|
||
|
void writeReg32Bit(uint16_t reg, uint32_t value);
|
||
|
uint8_t readReg(regAddr reg);
|
||
|
uint16_t readReg16Bit(uint16_t reg);
|
||
|
uint32_t readReg32Bit(uint16_t reg);
|
||
|
|
||
|
bool setDistanceMode(DistanceMode mode);
|
||
|
bool setDistanceModeInt(uint8_t mode);
|
||
|
DistanceMode getDistanceMode() { return distance_mode; }
|
||
|
|
||
|
bool setMeasurementTimingBudget(uint32_t budget_us);
|
||
|
uint32_t getMeasurementTimingBudget();
|
||
|
|
||
|
void startContinuous(uint32_t period_ms);
|
||
|
void stopContinuous();
|
||
|
uint16_t read(bool blocking = true);
|
||
|
uint16_t readRangeContinuousMillimeters(bool blocking = true) { return read(blocking); } // alias of read()
|
||
|
uint16_t readSingle(bool blocking = true);
|
||
|
uint16_t readRangeSingleMillimeters(bool blocking = true) { return readSingle(blocking); } // alias of readSingle()
|
||
|
|
||
|
// check if sensor has new reading available
|
||
|
// assumes interrupt is active low (GPIO_HV_MUX__CTRL bit 4 is 1)
|
||
|
bool dataReady() { return (readReg(GPIO__TIO_HV_STATUS) & 0x01) == 0; }
|
||
|
|
||
|
static const char * rangeStatusToString(RangeStatus status);
|
||
|
|
||
|
void setTimeout(uint16_t timeout) { io_timeout = timeout; }
|
||
|
uint16_t getTimeout() { return io_timeout; }
|
||
|
bool timeoutOccurred();
|
||
|
uint32_t getCurrMs() { return to_ms_since_boot(get_absolute_time()); }
|
||
|
|
||
|
private:
|
||
|
|
||
|
// The Arduino two-wire interface uses a 7-bit number for the address,
|
||
|
// and sets the last bit correctly based on reads and writes
|
||
|
static const uint8_t AddressDefault = 0b0101001;
|
||
|
|
||
|
// value used in measurement timing budget calculations
|
||
|
// assumes PresetMode is LOWPOWER_AUTONOMOUS
|
||
|
//
|
||
|
// vhv = LOWPOWER_AUTO_VHV_LOOP_DURATION_US + LOWPOWERAUTO_VHV_LOOP_BOUND
|
||
|
// (tuning parm default) * LOWPOWER_AUTO_VHV_LOOP_DURATION_US
|
||
|
// = 245 + 3 * 245 = 980
|
||
|
// TimingGuard = LOWPOWER_AUTO_OVERHEAD_BEFORE_A_RANGING +
|
||
|
// LOWPOWER_AUTO_OVERHEAD_BETWEEN_A_B_RANGING + vhv
|
||
|
// = 1448 + 2100 + 980 = 4528
|
||
|
static const uint32_t TimingGuard = 4528;
|
||
|
|
||
|
// value in DSS_CONFIG__TARGET_TOTAL_RATE_MCPS register, used in DSS
|
||
|
// calculations
|
||
|
static const uint16_t TargetRate = 0x0A00;
|
||
|
|
||
|
// for storing values read from RESULT__RANGE_STATUS (0x0089)
|
||
|
// through RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0_LOW
|
||
|
// (0x0099)
|
||
|
struct ResultBuffer
|
||
|
{
|
||
|
uint8_t range_status;
|
||
|
// uint8_t report_status: not used
|
||
|
uint8_t stream_count;
|
||
|
uint16_t dss_actual_effective_spads_sd0;
|
||
|
// uint16_t peak_signal_count_rate_mcps_sd0: not used
|
||
|
uint16_t ambient_count_rate_mcps_sd0;
|
||
|
// uint16_t sigma_sd0: not used
|
||
|
// uint16_t phase_sd0: not used
|
||
|
uint16_t final_crosstalk_corrected_range_mm_sd0;
|
||
|
uint16_t peak_signal_count_rate_crosstalk_corrected_mcps_sd0;
|
||
|
};
|
||
|
|
||
|
// making this static would save RAM for multiple instances as long as there
|
||
|
// aren't multiple sensors being read at the same time (e.g. on separate
|
||
|
// I2C buses)
|
||
|
ResultBuffer results;
|
||
|
|
||
|
uint16_t io_timeout;
|
||
|
bool did_timeout;
|
||
|
uint32_t timeout_start_ms;
|
||
|
|
||
|
uint16_t fast_osc_frequency;
|
||
|
uint16_t osc_calibrate_val;
|
||
|
|
||
|
bool calibrated;
|
||
|
uint8_t saved_vhv_init;
|
||
|
uint8_t saved_vhv_timeout;
|
||
|
|
||
|
DistanceMode distance_mode;
|
||
|
|
||
|
// Record the current time to check an upcoming timeout against
|
||
|
void startTimeout() { timeout_start_ms = to_ms_since_boot(get_absolute_time()); }
|
||
|
|
||
|
// Check if timeout is enabled (set to nonzero value) and has expired
|
||
|
bool checkTimeoutExpired() {return (io_timeout > 0) && ((to_ms_since_boot(get_absolute_time()) - timeout_start_ms) > io_timeout); }
|
||
|
|
||
|
void setupManualCalibration();
|
||
|
void readResults();
|
||
|
void updateDSS();
|
||
|
void getRangingData();
|
||
|
|
||
|
static uint32_t decodeTimeout(uint16_t reg_val);
|
||
|
static uint16_t encodeTimeout(uint32_t timeout_mclks);
|
||
|
static uint32_t timeoutMclksToMicroseconds(uint32_t timeout_mclks, uint32_t macro_period_us);
|
||
|
static uint32_t timeoutMicrosecondsToMclks(uint32_t timeout_us, uint32_t macro_period_us);
|
||
|
uint32_t calcMacroPeriod(uint8_t vcsel_period);
|
||
|
|
||
|
// Convert count rate from fixed point 9.7 format to float
|
||
|
float countRateFixedToFloat(uint16_t count_rate_fixed) { return (float)count_rate_fixed / (1 << 7); }
|
||
|
};
|
||
|
}
|