The VL53L1CB proximity sensor, based on ST’s FlightSense™, Time-of-Flight technology.

Dependencies:   X_NUCLEO_COMMON ST_INTERFACES

Dependents:   VL53L1CB_noshield_1sensor_polls_auton VL53L1CB_noshield_1sensor_interrupt_auton X_NUCLEO_53L1A2

Based on VL53L1 library, this is a library for the VL53L1CB ToF chip.

Revision:
10:3687b5e79f98
Parent:
9:66969b9016ad
diff -r 66969b9016ad -r 3687b5e79f98 src/VL53l1CB.cpp
--- a/src/VL53l1CB.cpp	Wed Jun 09 08:40:49 2021 +0100
+++ b/src/VL53l1CB.cpp	Wed Jun 09 10:09:49 2021 +0100
@@ -65,27 +65,27 @@
 #endif
 
 
-VL53L1_ERROR VL53L1::VL53L1_GetSWVersion(VL53L1_Version_t *pVersion)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetSWVersion(VL53L1_Version_t *pVersion)
 {
-    VL53L1_ERROR Status = 0;
+    VL53L1CB_ERROR Status = 0;
 
-    pVersion->major = VL53L1_IMPLEMENTATION_VER_MAJOR;
-    pVersion->minor = VL53L1_IMPLEMENTATION_VER_MINOR;
-    pVersion->build = VL53L1_IMPLEMENTATION_VER_SUB;
-    pVersion->revision = VL53L1_IMPLEMENTATION_VER_REVISION;
+    pVersion->major = VL53L1CB_IMPLEMENTATION_VER_MAJOR;
+    pVersion->minor = VL53L1CB_IMPLEMENTATION_VER_MINOR;
+    pVersion->build = VL53L1CB_IMPLEMENTATION_VER_SUB;
+    pVersion->revision = VL53L1CB_IMPLEMENTATION_VER_REVISION;
     return Status;
 }
 
-VL53L1_ERROR VL53L1::vl53L1_SetI2CAddress(uint8_t new_address)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetI2CAddress(uint8_t new_address)
 {
-    VL53L1_ERROR status = 0;
-  //  status = (VL53L1_ERROR)VL53L1_SetDeviceAddress(Device,new_address);
+    VL53L1CB_ERROR status = 0;
+  //  status = (VL53L1CB_ERROR)VL53L1_SetDeviceAddress(Device,new_address);
     
 
   //  Device->i2c_slave_address = new_address;  //~~ was
     if ( Device->i2c_slave_address != new_address)
     {
-        status = VL53L1_WrByte(Device, VL53L1_I2C_SLAVE__DEVICE_ADDRESS, new_address >> 1);   
+        status = VL53L1CB_WrByte(Device, VL53L1CB_I2C_SLAVE__DEVICE_ADDRESS, new_address >> 1);   
         printf("VL53L1_SetI2CAddress %d to %d status = %d\n", Device->i2c_slave_address,new_address,status);
                 Device->i2c_slave_address = new_address; 
 
@@ -93,12 +93,12 @@
     return status;
 }
 
-int VL53L1::init_sensor(uint8_t new_addr)
+int VL53L1CB::init_sensor(uint8_t new_addr)
 {
     Device->i2c_slave_address = new_addr;
     int status = 0;
-    VL53L1_Off();
-    VL53L1_On();
+    VL53L1CB_Off();
+    VL53L1CB_On();
 
     status = is_present();
     if (!status) {
@@ -109,13 +109,13 @@
 }
 
 
-VL53L1_ERROR VL53L1::VL53L1_SensorInit()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SensorInit()
 {
-    VL53L1_ERROR status = 0;
+    VL53L1CB_ERROR status = 0;
     uint8_t Addr = 0x00;
 
     for (Addr = 0x2D; Addr <= 0x87; Addr++){
-        status = VL53L1_WrByte(Device, Addr, VL51L1X_DEFAULT_CONFIGURATION[Addr - 0x2D]);
+        status = VL53L1CB_WrByte(Device, Addr, VL51L1X_DEFAULT_CONFIGURATION[Addr - 0x2D]);
         if (status != 0)
         {
             printf("Writing config failed - %d\r\n", status);
@@ -126,26 +126,26 @@
 //    status = VL53L1X_GetSensorId(&sensorID);
  //   printf("Sensor id is - %d (%X)\r\n", sensorID, sensorID);
     
-    status = VL53L1_StartRanging();
+    status = VL53L1CB_StartRanging();
     if (status != 0)
     {
         printf("start ranging failed - %d\r\n", status);
     }
  
-    status = VL53L1_ClearInterrupt();
-    status = VL53L1_StopRanging();
+    status = VL53L1CB_ClearInterrupt();
+    status = VL53L1CB_StopRanging();
     status = VL53L1_WrByte(Device, VL53L1_VHV_CONFIG__TIMEOUT_MACROP_LOOP_BOUND, 0x09); // two bounds VHV 
     status = VL53L1_WrByte(Device, 0x0B, 0); // start VHV from the previous temperature 
     return status;
 }
 
 
-VL53L1_ERROR VL53L1::VL53L1_ClearInterrupt()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_ClearInterrupt()
 {
-    VL53L1_ERROR status = 0;
+    VL53L1CB_ERROR status = 0;
 
-    status = VL53L1_WrByte(Device, SYSTEM__INTERRUPT_CLEAR, 0x01);
-//    printf("VL53L1::VL53L1X_ClearInterrupt()\n");
+    status = VL53L1CB_WrByte(Device, SYSTEM__INTERRUPT_CLEAR, 0x01);
+//    printf("VL53L1CB::VL53L1CBX_ClearInterrupt()\n");
     return status;
 }
 
@@ -153,12 +153,12 @@
 
 
 
-VL53L1_ERROR VL53L1::VL53L1_GetInterruptPolarity(uint8_t *pInterruptPolarity)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetInterruptPolarity(uint8_t *pInterruptPolarity)
 {
     uint8_t Temp;
-    VL53L1_ERROR status = 0;
+    VL53L1CB_ERROR status = 0;
 
-    status = VL53L1_RdByte(Device, GPIO_HV_MUX__CTRL, &Temp);
+    status = VL53L1CB_RdByte(Device, GPIO_HV_MUX__CTRL, &Temp);
     Temp = Temp & 0x10;
     *pInterruptPolarity = !(Temp>>4);
     return status;
@@ -166,44 +166,44 @@
 
 
 
-VL53L1_ERROR VL53L1::VL53L1_StartRanging()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_StartRanging()
 {
-    VL53L1_ERROR status = 0;
+    VL53L1CB_ERROR status = 0;
 
-    status = VL53L1_WrByte(Device, SYSTEM__MODE_START, 0x40); 
+    status = VL53L1CB_WrByte(Device, SYSTEM__MODE_START, 0x40); 
     return status;
 }
 
 
-VL53L1_ERROR VL53L1::VL53L1_StopRanging()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_StopRanging()
 {
-    VL53L1_ERROR status = 0;
+    VL53L1CB_ERROR status = 0;
 
-    status = VL53L1_WrByte(Device, SYSTEM__MODE_START, 0x00);   
+    status = VL53L1CB_WrByte(Device, SYSTEM__MODE_START, 0x00);   
     return status;
 }
 
 
 
 
-VL53L1_ERROR VL53L1::vl53L1_BootState(uint8_t *state)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_BootState(uint8_t *state)
 {
-    VL53L1_ERROR status = 0;
+    VL53L1CB_ERROR status = 0;
     uint8_t tmp = 0;
 
-    status = VL53L1_RdByte(Device,VL53L1_FIRMWARE__SYSTEM_STATUS, &tmp);
+    status = VL53L1CB_RdByte(Device,VL53L1CB_FIRMWARE__SYSTEM_STATUS, &tmp);
     *state = tmp;
     return status;
 }
 
 
-VL53L1_ERROR VL53L1::VL53L1_GetDistance(uint16_t *distance)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetDistance(uint16_t *distance)
 {
-    VL53L1_ERROR status = 0;
+    VL53L1CB_ERROR status = 0;
     uint16_t tmp;
 
-    status = (VL53L1_RdWord(Device,
-            VL53L1_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0, &tmp));
+    status = (VL53L1CB_RdWord(Device,
+            VL53L1CB_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0, &tmp));
     *distance = tmp;
     return status;
 }
@@ -212,44 +212,44 @@
     /* Write and read functions from I2C */
 
 
-VL53L1_ERROR VL53L1::VL53L1_WriteMulti(VL53L1_DEV Dev, uint16_t index, uint8_t *pdata, uint32_t count)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_WriteMulti(VL53L1_DEV Dev, uint16_t index, uint8_t *pdata, uint32_t count)
 {
    int  status;
 //printf(" class VL53L1_WriteMulti \n");
-   status = VL53L1_I2CWrite(Dev->i2c_slave_address, index, pdata, (uint16_t)count);
+   status = VL53L1CB_I2CWrite(Dev->i2c_slave_address, index, pdata, (uint16_t)count);
    return status;
 }
 
-VL53L1_ERROR VL53L1::VL53L1_ReadMulti(VL53L1_DEV Dev, uint16_t index, uint8_t *pdata, uint32_t count)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_ReadMulti(VL53L1_DEV Dev, uint16_t index, uint8_t *pdata, uint32_t count)
 {
     int status;
 
-    status = VL53L1_I2CRead(Dev->i2c_slave_address, index, pdata, (uint16_t)count);
+    status = VL53L1CB_I2CRead(Dev->i2c_slave_address, index, pdata, (uint16_t)count);
 
     return status;
 }
 
 
-VL53L1_ERROR VL53L1::VL53L1_WrByte(VL53L1_DEV Dev, uint16_t index, uint8_t data)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_WrByte(VL53L1_DEV Dev, uint16_t index, uint8_t data)
 {
    int  status;
 
-   status=VL53L1_I2CWrite(Dev->i2c_slave_address, index, &data, 1);
+   status=VL53L1CB_I2CWrite(Dev->i2c_slave_address, index, &data, 1);
    return status;
 }
 
-VL53L1_ERROR VL53L1::VL53L1_WrWord(VL53L1_DEV Dev, uint16_t index, uint16_t data)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_WrWord(VL53L1_DEV Dev, uint16_t index, uint16_t data)
 {
    int  status;
    uint8_t buffer[2];
 
      buffer[0] = data >> 8;
      buffer[1] = data & 0x00FF;
-   status=VL53L1_I2CWrite(Dev->i2c_slave_address, index, (uint8_t *)buffer, 2);
+   status=VL53L1CB_I2CWrite(Dev->i2c_slave_address, index, (uint8_t *)buffer, 2);
    return status;
 }
 
-VL53L1_ERROR VL53L1::VL53L1_WrDWord(VL53L1_DEV Dev, uint16_t index, uint32_t data)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_WrDWord(VL53L1_DEV Dev, uint16_t index, uint32_t data)
 {
    int  status;
    uint8_t buffer[4];
@@ -258,16 +258,16 @@
      buffer[1] = (data >> 16) & 0xFF;
      buffer[2] = (data >>  8) & 0xFF;
      buffer[3] = (data >>  0) & 0xFF;
-   status=VL53L1_I2CWrite(Dev->i2c_slave_address, index, (uint8_t *)buffer, 4);
+   status=VL53L1CB_I2CWrite(Dev->i2c_slave_address, index, (uint8_t *)buffer, 4);
    return status;
 }
 
 
-VL53L1_ERROR VL53L1::VL53L1_RdByte(VL53L1_DEV Dev, uint16_t index, uint8_t *data)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_RdByte(VL53L1_DEV Dev, uint16_t index, uint8_t *data)
 {
    int  status;
 
-   status = VL53L1_I2CRead(Dev->i2c_slave_address, index, data, 1);
+   status = VL53L1CB_I2CRead(Dev->i2c_slave_address, index, data, 1);
 
    if(status)
      return -1;
@@ -275,12 +275,12 @@
    return 0;
 }
 
-VL53L1_ERROR VL53L1::VL53L1_RdWord(VL53L1_DEV Dev, uint16_t index, uint16_t *data)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_RdWord(VL53L1_DEV Dev, uint16_t index, uint16_t *data)
 {
    int  status;
    uint8_t buffer[2] = {0,0};
 
-   status = VL53L1_I2CRead(Dev->i2c_slave_address, index, buffer, 2);
+   status = VL53L1CB_I2CRead(Dev->i2c_slave_address, index, buffer, 2);
    if (!status)
    {
        *data = (buffer[0] << 8) + buffer[1];
@@ -290,12 +290,12 @@
 
 }
 
-VL53L1_ERROR VL53L1::VL53L1_RdDWord(VL53L1_DEV Dev, uint16_t index, uint32_t *data)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_RdDWord(VL53L1_DEV Dev, uint16_t index, uint32_t *data)
 {
    int status;
    uint8_t buffer[4] = {0,0,0,0};
 
-   status = VL53L1_I2CRead(Dev->i2c_slave_address, index, buffer, 4);
+   status = VL53L1CB_I2CRead(Dev->i2c_slave_address, index, buffer, 4);
    if(!status)
    {
        *data = (buffer[0] << 24) + (buffer[1] << 16) + (buffer[2] << 8) + buffer[3];
@@ -304,22 +304,22 @@
 
 }
 
-VL53L1_ERROR VL53L1::VL53L1_UpdateByte(VL53L1_DEV Dev, uint16_t index, uint8_t AndData, uint8_t OrData)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_UpdateByte(VL53L1_DEV Dev, uint16_t index, uint8_t AndData, uint8_t OrData)
 {
    int  status;
    uint8_t buffer = 0;
 
    /* read data direct onto buffer */
-   status = VL53L1_I2CRead(Dev->i2c_slave_address, index, &buffer,1);
+   status = VL53L1CB_I2CRead(Dev->i2c_slave_address, index, &buffer,1);
    if (!status)
    {
       buffer = (buffer & AndData) | OrData;
-      status = VL53L1_I2CWrite(Dev->i2c_slave_address, index, &buffer, (uint16_t)1);
+      status = VL53L1CB_I2CWrite(Dev->i2c_slave_address, index, &buffer, (uint16_t)1);
    }
    return status;
 }
 
-VL53L1_ERROR VL53L1::VL53L1_I2CWrite(uint8_t DeviceAddr, uint16_t RegisterAddr, uint8_t* pBuffer, uint16_t NumByteToWrite)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_I2CWrite(uint8_t DeviceAddr, uint16_t RegisterAddr, uint8_t* pBuffer, uint16_t NumByteToWrite)
 {
     int ret;
     ret = dev_i2c->ToF_i2c_write(pBuffer, DeviceAddr, RegisterAddr, NumByteToWrite);
@@ -330,7 +330,7 @@
 
 }
 
-VL53L1_ERROR VL53L1::VL53L1_I2CRead(uint8_t DeviceAddr, uint16_t RegisterAddr, uint8_t* pBuffer, uint16_t NumByteToRead)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_I2CRead(uint8_t DeviceAddr, uint16_t RegisterAddr, uint8_t* pBuffer, uint16_t NumByteToRead)
 {
     int ret;
 
@@ -343,13 +343,13 @@
 }
 
 
-VL53L1_ERROR VL53L1::VL53L1_GetTickCount(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetTickCount(
     uint32_t *ptick_count_ms)
 {
 
     /* Returns current tick count in [ms] */
 
-    VL53L1_ERROR status  = VL53L1_ERROR_NONE;
+    VL53L1CB_ERROR status  = VL53L1_ERROR_NONE;
 
     //*ptick_count_ms = timeGetTime();
     *ptick_count_ms = us_ticker_read() / 1000;
@@ -359,7 +359,7 @@
 
 
 
-VL53L1_ERROR VL53L1::VL53L1_WaitUs(VL53L1_Dev_t *pdev, int32_t wait_time)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_WaitUs(VL53L1_Dev_t *pdev, int32_t wait_time)
 {
     //(void)pdev;
       wait_us(wait_time);
@@ -367,7 +367,7 @@
 }
 
 
-VL53L1_ERROR VL53L1::VL53L1_WaitMs(VL53L1_Dev_t *pdev, int32_t wait_time)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_WaitMs(VL53L1_Dev_t *pdev, int32_t wait_time)
 {
     //(void)pdev;
 
@@ -380,7 +380,7 @@
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_WaitValueMaskEx(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_WaitValueMaskEx(
     VL53L1_Dev_t *pdev,
     uint32_t      timeout_ms,
     uint16_t      index,
@@ -406,9 +406,9 @@
 
 
 /***************************************************************************/
-//VL53L1_ERROR VL53L1::VL53L1_WaitValueMaskEx(
+//VL53L1CB_ERROR VL53L1CB::VL53L1CB_WaitValueMaskEx(
 
-VL53L1_ERROR VL53L1::vl53L1_WaitDeviceBooted(VL53L1_DEV Dev)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_WaitDeviceBooted(VL53L1_DEV Dev)
 {
 
     return VL53L1_WaitDeviceBooted(Dev);
@@ -430,14 +430,14 @@
 };
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetVersion(VL53L1_Version_t *pVersion)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetVersion(VL53L1_Version_t *pVersion)
 {
 
     return VL53L1_GetVersion(pVersion);
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetProductRevision(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetProductRevision(
     uint8_t *pProductRevisionMajor, uint8_t *pProductRevisionMinor)
 {
     return VL53L1_GetProductRevision(Device,pProductRevisionMajor,pProductRevisionMinor);
@@ -446,103 +446,103 @@
 //******************************************************************
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetDeviceInfo(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetDeviceInfo(
     VL53L1_DeviceInfo_t *pVL53L1_DeviceInfo)
 {
     return VL53L1_GetDeviceInfo(Device,pVL53L1_DeviceInfo);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetUID( uint64_t *pUid)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetUID( uint64_t *pUid)
 {
     return VL53L1_GetUID(Device,pUid);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetRangeStatusString(uint8_t RangeStatus,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetRangeStatusString(uint8_t RangeStatus,
     char *pRangeStatusString)
 {
     return VL53L1_GetRangeStatusString(RangeStatus,
         pRangeStatusString);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetPalErrorString(VL53L1_Error PalErrorCode,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetPalErrorString(VL53L1CB_ERROR PalErrorCode,
     char *pPalErrorString)
 {
     return VL53L1_GetPalErrorString(PalErrorCode,pPalErrorString);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetPalStateString(VL53L1_State PalStateCode,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetPalStateString(VL53L1_State PalStateCode,
     char *pPalStateString)
 {
     return VL53L1_GetPalStateString(PalStateCode, pPalStateString);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetPalState(VL53L1_DEV Dev, VL53L1_State *pPalState)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetPalState(VL53L1_DEV Dev, VL53L1_State *pPalState)
 {
     return VL53L1_GetPalState(Dev,pPalState);
 }
 
 
-VL53L1_ERROR VL53L1::VL53L1_SetDeviceAddress(VL53L1_DEV Dev, uint8_t DeviceAddress)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetDeviceAddress(VL53L1_DEV Dev, uint8_t DeviceAddress)
 {
-    VL53L1_Error Status = VL53L1_ERROR_NONE;
+    VL53L1CB_ERROR Status = VL53L1_ERROR_NONE;
 
  //   LOG_FUNCTION_START("");
 
-    Status = VL53L1_WrByte(Dev, VL53L1_I2C_SLAVE__DEVICE_ADDRESS,
+    Status = VL53L1_WrByte(Dev, VL53L1CB_I2C_SLAVE__DEVICE_ADDRESS,
             DeviceAddress / 2);
 
 //    LOG_FUNCTION_END(Status);
     return Status;
 }
 
-VL53L1_ERROR VL53L1::vl53L1_DataInit()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_DataInit()
 {
     printf("vl53L1_DataInit %d \n",Device->i2c_slave_address);
     return VL53L1_DataInit( Device);
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_StaticInit()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_StaticInit()
 {
     return VL53L1_StaticInit( Device);
 }
 
 
- VL53L1_ERROR VL53L1::vl53L1_SetPresetMode(VL53L1_PresetModes PresetMode)
+ VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetPresetMode(VL53L1_PresetModes PresetMode)
 {
     return VL53L1_SetPresetMode(Device,PresetMode);
 }
 
 
- VL53L1_ERROR VL53L1::vl53L1_GetPresetMode( VL53L1_PresetModes *pPresetMode)
+ VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetPresetMode( VL53L1_PresetModes *pPresetMode)
 {
     return VL53L1_GetPresetMode(Device,pPresetMode);
 }
 
 
- VL53L1_ERROR VL53L1::vl53L1_SetDistanceMode(VL53L1_DistanceModes DistanceMode)
+ VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetDistanceMode(VL53L1_DistanceModes DistanceMode)
 {
     return VL53L1_SetDistanceMode(Device,DistanceMode);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetDistanceMode(VL53L1_DistanceModes *pDistanceMode)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetDistanceMode(VL53L1_DistanceModes *pDistanceMode)
 {
     return VL53L1_GetDistanceMode(Device,pDistanceMode);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_SetOutputMode(VL53L1_OutputModes OutputMode)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetOutputMode(VL53L1_OutputModes OutputMode)
 {
     return VL53L1_SetOutputMode(Device,OutputMode);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetOutputMode(VL53L1_OutputModes *pOutputMode)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetOutputMode(VL53L1_OutputModes *pOutputMode)
 {
     return VL53L1_GetOutputMode(Device,pOutputMode);
 }
 
 
 
-VL53L1_ERROR VL53L1::vl53L1_SetMeasurementTimingBudgetMicroSeconds(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetMeasurementTimingBudgetMicroSeconds(
                                    uint32_t MeasurementTimingBudgetMicroSeconds)
 {
     return VL53L1_SetMeasurementTimingBudgetMicroSeconds(Device,
@@ -550,7 +550,7 @@
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetMeasurementTimingBudgetMicroSeconds(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetMeasurementTimingBudgetMicroSeconds(
                                  uint32_t *pMeasurementTimingBudgetMicroSeconds)
 {
     return VL53L1_GetMeasurementTimingBudgetMicroSeconds(Device,
@@ -559,38 +559,38 @@
 
 
 
-VL53L1_ERROR VL53L1::vl53L1_SetInterMeasurementPeriodMilliSeconds(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetInterMeasurementPeriodMilliSeconds(
     uint32_t InterMeasurementPeriodMilliSeconds)
 {   
     return VL53L1_SetInterMeasurementPeriodMilliSeconds(Device,InterMeasurementPeriodMilliSeconds);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetInterMeasurementPeriodMilliSeconds(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetInterMeasurementPeriodMilliSeconds(
     uint32_t *pInterMeasurementPeriodMilliSeconds)
 {
     return VL53L1_GetInterMeasurementPeriodMilliSeconds(Device,pInterMeasurementPeriodMilliSeconds);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_SetDmaxReflectance(FixPoint1616_t DmaxReflectance)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetDmaxReflectance(FixPoint1616_t DmaxReflectance)
 {
 
     return VL53L1_SetDmaxReflectance(Device,DmaxReflectance);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetDmaxReflectance(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetDmaxReflectance(
                                            FixPoint1616_t *pDmaxReflectance)
 {
     return VL53L1_GetDmaxReflectance(Device,pDmaxReflectance);
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_SetDmaxMode(VL53L1_DeviceDmaxModes DmaxMode)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetDmaxMode(VL53L1_DeviceDmaxModes DmaxMode)
 {
     return VL53L1_SetDmaxMode(Device,DmaxMode);
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetDmaxMode(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetDmaxMode(
     VL53L1_DeviceDmaxModes *pDmaxMode)
 {
     return VL53L1_GetDmaxMode(Device,pDmaxMode);
@@ -598,9 +598,9 @@
 
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetNumberOfLimitCheck(uint16_t *pNumberOfLimitCheck)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetNumberOfLimitCheck(uint16_t *pNumberOfLimitCheck)
 {
-    VL53L1_Error Status = VL53L1_ERROR_NONE;
+    VL53L1CB_ERROR Status = VL53L1_ERROR_NONE;
 
   //  LOG_FUNCTION_START("");
 
@@ -610,7 +610,7 @@
     return Status;
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetLimitCheckInfo(uint16_t LimitCheckId,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetLimitCheckInfo(uint16_t LimitCheckId,
     char *pLimitCheckString)
 {
     return VL53L1_GetLimitCheckInfo(LimitCheckId,
@@ -618,67 +618,64 @@
 
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetLimitCheckStatus(uint16_t LimitCheckId,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetLimitCheckStatus(uint16_t LimitCheckId,
     uint8_t *pLimitCheckStatus)
 {
     return VL53L1_GetLimitCheckStatus(Device,LimitCheckId,pLimitCheckStatus);
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_SetLimitCheckEnable(uint16_t LimitCheckId,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetLimitCheckEnable(uint16_t LimitCheckId,
     uint8_t LimitCheckEnable)
 {
 
     return VL53L1_SetLimitCheckEnable(Device,LimitCheckId,LimitCheckEnable);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetLimitCheckEnable(uint16_t LimitCheckId,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetLimitCheckEnable(uint16_t LimitCheckId,
     uint8_t *pLimitCheckEnable)
 {
     return VL53L1_GetLimitCheckEnable(Device,LimitCheckId,pLimitCheckEnable);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_SetLimitCheckValue( uint16_t LimitCheckId,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetLimitCheckValue( uint16_t LimitCheckId,
     FixPoint1616_t LimitCheckValue)
 {
     return VL53L1_SetLimitCheckValue(Device,LimitCheckId,LimitCheckValue);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetLimitCheckValue( uint16_t LimitCheckId,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetLimitCheckValue( uint16_t LimitCheckId,
     FixPoint1616_t *pLimitCheckValue)
 {
     return VL53L1_GetLimitCheckValue(Device,LimitCheckId,pLimitCheckValue);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetLimitCheckCurrent( uint16_t LimitCheckId,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetLimitCheckCurrent( uint16_t LimitCheckId,
     FixPoint1616_t *pLimitCheckCurrent)
 {
     return VL53L1_GetLimitCheckCurrent(Device,LimitCheckId,pLimitCheckCurrent);
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetMaxNumberOfROI( uint8_t *pMaxNumberOfROI)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetMaxNumberOfROI( uint8_t *pMaxNumberOfROI)
 {
     return VL53L1_GetMaxNumberOfROI(Device,pMaxNumberOfROI);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_SetROI( VL53L1_RoiConfig_t *pRoiConfig)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetROI( VL53L1_RoiConfig_t *pRoiConfig)
 {
 
     return VL53L1_SetROI(Device,pRoiConfig);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetROI(VL53L1_RoiConfig_t *pRoiConfig)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetROI(VL53L1_RoiConfig_t *pRoiConfig)
 {
     return VL53L1_GetROI(Device,pRoiConfig);
 }
 
-
-
-
-VL53L1_ERROR VL53L1::vl53L1_GetNumberOfSequenceSteps(uint8_t *pNumberOfSequenceSteps)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetNumberOfSequenceSteps(uint8_t *pNumberOfSequenceSteps)
 {
-    VL53L1_Error Status = VL53L1_ERROR_NONE;
+    VL53L1CB_ERROR Status = VL53L1_ERROR_NONE;
 
  //   SUPPRESS_UNUSED_WARNING(Dev);
 
@@ -690,13 +687,13 @@
     return Status;
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetSequenceStepsInfo(VL53L1_SequenceStepId SequenceStepId,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetSequenceStepsInfo(VL53L1_SequenceStepId SequenceStepId,
     char *pSequenceStepsString)
 {
     return VL53L1_GetSequenceStepsInfo(SequenceStepId,pSequenceStepsString);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_SetSequenceStepEnable(VL53L1_SequenceStepId SequenceStepId,
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetSequenceStepEnable(VL53L1_SequenceStepId SequenceStepId,
                                                     uint8_t SequenceStepEnabled)
 {
 
@@ -704,7 +701,7 @@
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetSequenceStepEnable(VL53L1_SequenceStepId SequenceStepId, 
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetSequenceStepEnable(VL53L1_SequenceStepId SequenceStepId, 
                                                     uint8_t *pSequenceStepEnabled)
 {
     return VL53L1_GetSequenceStepEnable(Device,SequenceStepId,pSequenceStepEnabled);
@@ -712,30 +709,30 @@
 
 
 
-VL53L1_ERROR VL53L1::vl53L1_StartMeasurement()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_StartMeasurement()
 {
     return VL53L1_StartMeasurement(Device);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_StopMeasurement()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_StopMeasurement()
 {
     return VL53L1_StopMeasurement(Device);
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_ClearInterruptAndStartMeasurement()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_ClearInterruptAndStartMeasurement()
 {
 
     return VL53L1_ClearInterruptAndStartMeasurement(Device);
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetMeasurementDataReady(uint8_t *pMeasurementDataReady)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetMeasurementDataReady(uint8_t *pMeasurementDataReady)
 {
     return VL53L1_GetMeasurementDataReady(Device, pMeasurementDataReady);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_WaitMeasurementDataReady()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_WaitMeasurementDataReady()
 {
     return VL53L1_WaitMeasurementDataReady(Device);
 }
@@ -745,22 +742,22 @@
 
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetCalibrationData(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetCalibrationData(
         VL53L1_CalibrationData_t  *pCalibrationData)
 {
     
-    VL53L1_Error Status = VL53L1_ERROR_NONE;
+    VL53L1CB_ERROR Status = VL53L1_ERROR_NONE;
     Status = VL53L1_GetCalibrationData(Device,pCalibrationData);
 
     return Status;
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetRangingMeasurementData(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetRangingMeasurementData(
     VL53L1_RangingMeasurementData_t *pRangingMeasurementData)
 {
 //              printf("   VL53L1_GetRangingMeasurementData 000  \n");  
-    VL53L1_Error Status = VL53L1_ERROR_NONE;
+    VL53L1CB_ERROR Status = VL53L1_ERROR_NONE;
     Status = VL53L1_GetRangingMeasurementData(Device,pRangingMeasurementData);
 
     return Status;
@@ -770,13 +767,13 @@
 
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetMultiRangingData(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetMultiRangingData(
         VL53L1_MultiRangingData_t *pMultiRangingData)
 {
     return VL53L1_GetMultiRangingData(Device,pMultiRangingData);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetAdditionalData(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetAdditionalData(
         VL53L1_AdditionalData_t *pAdditionalData)
 {
     return VL53L1_GetAdditionalData(Device, pAdditionalData);
@@ -784,13 +781,13 @@
 
 
 
-VL53L1_ERROR VL53L1::vl53L1_SetTuningParameter(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetTuningParameter(
         uint16_t TuningParameterId, int32_t TuningParameterValue)
 {
     return VL53L1_SetTuningParameter(Device,TuningParameterId,TuningParameterValue);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetTuningParameter(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetTuningParameter(
         uint16_t TuningParameterId, int32_t *pTuningParameterValue)
 {
 
@@ -798,7 +795,7 @@
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_SetXTalkCompensationEnable(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetXTalkCompensationEnable(
     uint8_t XTalkCompensationEnable)
 {
 
@@ -806,10 +803,10 @@
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetXTalkCompensationEnable(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetXTalkCompensationEnable(
     uint8_t *pXTalkCompensationEnable)
 {
-    VL53L1_Error Status = VL53L1_ERROR_NONE;
+    VL53L1CB_ERROR Status = VL53L1_ERROR_NONE;
 
   //  LOG_FUNCTION_START("");
 
@@ -822,95 +819,87 @@
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_PerformXTalkCalibration(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_PerformXTalkCalibration(
         uint8_t CalibrationOption)
 {
 
     return VL53L1_PerformXTalkCalibration(Device,CalibrationOption);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_SetOffsetCalibrationMode(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetOffsetCalibrationMode(
         VL53L1_OffsetCalibrationModes OffsetCalibrationMode)
 {
     return VL53L1_SetOffsetCalibrationMode(Device,OffsetCalibrationMode);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_SetOffsetCorrectionMode(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetOffsetCorrectionMode(
         VL53L1_OffsetCorrectionModes OffsetCorrectionMode)
 {
     return  VL53L1_SetOffsetCorrectionMode(Device,OffsetCorrectionMode);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_PerformOffsetCalibration(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_PerformOffsetCalibration(
     int32_t CalDistanceMilliMeter, FixPoint1616_t CalReflectancePercent)
 {
     return VL53L1_PerformOffsetCalibration(Device,CalDistanceMilliMeter,CalReflectancePercent);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_PerformOffsetSimpleCalibration(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_PerformOffsetSimpleCalibration(
     int32_t CalDistanceMilliMeter)
 {
     return VL53L1_PerformOffsetSimpleCalibration(Device,CalDistanceMilliMeter);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_PerformOffsetZeroDistanceCalibration()
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_PerformOffsetZeroDistanceCalibration()
 {
     return VL53L1_PerformOffsetZeroDistanceCalibration(Device);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_SetCalibrationData(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetCalibrationData(
         VL53L1_CalibrationData_t *pCalibrationData)
 {
     return VL53L1_SetCalibrationData(Device,pCalibrationData);
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_SetZoneCalibrationData(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetZoneCalibrationData(
         VL53L1_ZoneCalibrationData_t *pZoneCalibrationData)
 {
     return VL53L1_SetZoneCalibrationData(Device, pZoneCalibrationData);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetZoneCalibrationData(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetZoneCalibrationData(
         VL53L1_ZoneCalibrationData_t  *pZoneCalibrationData)
 {
     return VL53L1_GetZoneCalibrationData(Device, pZoneCalibrationData);
 }
 
-VL53L1_Error VL53L1::vl53L1_SmudgeCorrectionEnable(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SmudgeCorrectionEnable(
         VL53L1_SmudgeCorrectionModes Mode)
         
 {
     return VL53L1_SmudgeCorrectionEnable(Device, Mode);
 }
 
-VL53L1_ERROR VL53L1::vl53L1_GetOpticalCenter(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetOpticalCenter(
         FixPoint1616_t *pOpticalCenterX,
         FixPoint1616_t *pOpticalCenterY)
 {
     return VL53L1_GetOpticalCenter(Device,pOpticalCenterX,pOpticalCenterY);
 }
 
-
-
-
-
-
-VL53L1_ERROR VL53L1::vl53L1_SetThresholdConfig(VL53L1_DetectionConfig_t *pConfig)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_SetThresholdConfig(VL53L1_DetectionConfig_t *pConfig)
 {
     return VL53L1_SetThresholdConfig(Device,pConfig);
 }
 
 
-VL53L1_ERROR VL53L1::vl53L1_GetThresholdConfig(VL53L1_DetectionConfig_t *pConfig)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_GetThresholdConfig(VL53L1_DetectionConfig_t *pConfig)
 {
     return VL53L1_GetThresholdConfig(Device,pConfig);
 }
 
-
-
-
-VL53L1_ERROR VL53L1::vl53L1_PerformOffsetPerVcselCalibration(int32_t CalDistanceMilliMeter)
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_PerformOffsetPerVcselCalibration(int32_t CalDistanceMilliMeter)
 {
     return VL53L1_PerformOffsetPerVcselCalibration(Device,CalDistanceMilliMeter);
 }
@@ -920,7 +909,7 @@
 // from vl53l1_api_debug.c
 
 
-VL53L1_ERROR VL53L1::vl53L1_get_additional_data(
+VL53L1CB_ERROR VL53L1CB::VL53L1CB_get_additional_data(
     VL53L1_DEV                      Dev,
     VL53L1_additional_data_t        *pdata)
 {
@@ -929,7 +918,7 @@
 
 
 
-int VL53L1::handle_irq(uint16_t *distance)
+int VL53L1CB::handle_irq(uint16_t *distance)
 {
     int status;
     status = get_measurement(distance);
@@ -937,17 +926,17 @@
     return status;
 }
 
-int VL53L1::get_measurement(uint16_t *distance)
+int VL53L1CB::get_measurement(uint16_t *distance)
 {
     int status = 0;
 
-    status = VL53L1_GetDistance(distance);
-    status = VL53L1_ClearInterrupt();
+    status = VL53L1CB_GetDistance(distance);
+    status = VL53L1CB_ClearInterrupt();
 
     return status;
 }
 
-int VL53L1::start_measurement(void (*fptr)(void))
+int VL53L1CB::start_measurement(void (*fptr)(void))
 {
     int status = 0;
 
@@ -956,7 +945,7 @@
         return 1;
     }
 
-    status = VL53L1_StopRanging(); // it is safer to do this while sensor is stopped
+    status = VL53L1CB_StopRanging(); // it is safer to do this while sensor is stopped
 
     if (status == 0) {
         attach_interrupt_measure_detection_irq(fptr);
@@ -964,23 +953,23 @@
     }
 
     if (status == 0) {
-        status = VL53L1_StartRanging();
+        status = VL53L1CB_StartRanging();
     }
 
     return status;
 }
 
-int VL53L1::stop_measurement()
+int VL53L1CB::stop_measurement()
 {
     int status = 0;
 
     if (status == 0) {
         printf("Call of VL53L1_StopMeasurement\n");
-        status = VL53L1_StopRanging();
+        status = VL53L1CB_StopRanging();
     }
 
     if (status == 0)
-        status = VL53L1_ClearInterrupt();
+        status = VL53L1CB_ClearInterrupt();
 
     return status;
 }