Ivan Podogov 3 лет назад
Родитель
Сommit
1954e3bd3d

+ 29 - 16
air_mouse.c

@@ -16,13 +16,13 @@ enum AirMouseSubmenuIndex {
 void air_mouse_submenu_callback(void* context, uint32_t index) {
     furi_assert(context);
     AirMouse* app = context;
-    if (index == AirMouseSubmenuIndexBtMouse) {
+    if(index == AirMouseSubmenuIndexBtMouse) {
         app->view_id = AirMouseViewBtMouse;
         view_dispatcher_switch_to_view(app->view_dispatcher, AirMouseViewBtMouse);
-    } else if (index == AirMouseSubmenuIndexUsbMouse) {
+    } else if(index == AirMouseSubmenuIndexUsbMouse) {
         app->view_id = AirMouseViewUsbMouse;
         view_dispatcher_switch_to_view(app->view_dispatcher, AirMouseViewUsbMouse);
-    } else if (index == AirMouseSubmenuIndexCalibration) {
+    } else if(index == AirMouseSubmenuIndexCalibration) {
         app->view_id = AirMouseViewCalibration;
         view_dispatcher_switch_to_view(app->view_dispatcher, AirMouseViewCalibration);
     }
@@ -31,11 +31,11 @@ void air_mouse_submenu_callback(void* context, uint32_t index) {
 void air_mouse_dialog_callback(DialogExResult result, void* context) {
     furi_assert(context);
     AirMouse* app = context;
-    if (result == DialogExResultLeft) {
+    if(result == DialogExResultLeft) {
         view_dispatcher_switch_to_view(app->view_dispatcher, VIEW_NONE); // Exit
-    } else if (result == DialogExResultRight) {
+    } else if(result == DialogExResultRight) {
         view_dispatcher_switch_to_view(app->view_dispatcher, app->view_id); // Show last view
-    } else if (result == DialogExResultCenter) {
+    } else if(result == DialogExResultCenter) {
         view_dispatcher_switch_to_view(app->view_dispatcher, AirMouseViewSubmenu); // Menu
     }
 }
@@ -63,11 +63,19 @@ AirMouse* air_mouse_app_alloc() {
 
     // Submenu view
     app->submenu = submenu_alloc();
-    submenu_add_item(app->submenu, "Bluetooth", AirMouseSubmenuIndexBtMouse, air_mouse_submenu_callback, app);
-    submenu_add_item(app->submenu, "USB", AirMouseSubmenuIndexUsbMouse, air_mouse_submenu_callback, app);
-    submenu_add_item(app->submenu, "Calibration", AirMouseSubmenuIndexCalibration, air_mouse_submenu_callback, app);
+    submenu_add_item(
+        app->submenu, "Bluetooth", AirMouseSubmenuIndexBtMouse, air_mouse_submenu_callback, app);
+    submenu_add_item(
+        app->submenu, "USB", AirMouseSubmenuIndexUsbMouse, air_mouse_submenu_callback, app);
+    submenu_add_item(
+        app->submenu,
+        "Calibration",
+        AirMouseSubmenuIndexCalibration,
+        air_mouse_submenu_callback,
+        app);
     view_set_previous_callback(submenu_get_view(app->submenu), air_mouse_exit);
-    view_dispatcher_add_view(app->view_dispatcher, AirMouseViewSubmenu, submenu_get_view(app->submenu));
+    view_dispatcher_add_view(
+        app->view_dispatcher, AirMouseViewSubmenu, submenu_get_view(app->submenu));
 
     // Dialog view
     app->dialog = dialog_ex_alloc();
@@ -77,22 +85,27 @@ AirMouse* air_mouse_app_alloc() {
     dialog_ex_set_right_button_text(app->dialog, "Stay");
     dialog_ex_set_center_button_text(app->dialog, "Menu");
     dialog_ex_set_header(app->dialog, "Close Current App?", 16, 12, AlignLeft, AlignTop);
-    view_dispatcher_add_view(app->view_dispatcher, AirMouseViewExitConfirm, dialog_ex_get_view(app->dialog));
+    view_dispatcher_add_view(
+        app->view_dispatcher, AirMouseViewExitConfirm, dialog_ex_get_view(app->dialog));
 
     // Bluetooth view
     app->bt_mouse = bt_mouse_alloc(app->view_dispatcher);
     view_set_previous_callback(bt_mouse_get_view(app->bt_mouse), air_mouse_exit_confirm_view);
-    view_dispatcher_add_view(app->view_dispatcher, AirMouseViewBtMouse, bt_mouse_get_view(app->bt_mouse));
+    view_dispatcher_add_view(
+        app->view_dispatcher, AirMouseViewBtMouse, bt_mouse_get_view(app->bt_mouse));
 
     // USB view
     app->usb_mouse = usb_mouse_alloc(app->view_dispatcher);
     view_set_previous_callback(usb_mouse_get_view(app->usb_mouse), air_mouse_exit_confirm_view);
-    view_dispatcher_add_view(app->view_dispatcher, AirMouseViewUsbMouse, usb_mouse_get_view(app->usb_mouse));
+    view_dispatcher_add_view(
+        app->view_dispatcher, AirMouseViewUsbMouse, usb_mouse_get_view(app->usb_mouse));
 
     // Calibration view
     app->calibration = calibration_alloc(app->view_dispatcher);
-    view_set_previous_callback(calibration_get_view(app->calibration), air_mouse_exit_confirm_view);
-    view_dispatcher_add_view(app->view_dispatcher, AirMouseViewCalibration, calibration_get_view(app->calibration));
+    view_set_previous_callback(
+        calibration_get_view(app->calibration), air_mouse_exit_confirm_view);
+    view_dispatcher_add_view(
+        app->view_dispatcher, AirMouseViewCalibration, calibration_get_view(app->calibration));
 
     app->view_id = AirMouseViewSubmenu;
     view_dispatcher_switch_to_view(app->view_dispatcher, app->view_id);
@@ -128,7 +141,7 @@ int32_t air_mouse_app(void* p) {
     UNUSED(p);
 
     AirMouse* app = air_mouse_app_alloc();
-    if (!imu_begin()) {
+    if(!imu_begin()) {
         air_mouse_app_free(app);
         return -1;
     }

+ 25 - 16
tracking/calibration_data.h

@@ -11,20 +11,20 @@
 #define CALIBRATION_DATA_PATH INT_PATH(CALIBRATION_DATA_FILE_NAME)
 #define CALIBRATION_DATA_MAGIC (0x23)
 
-#define CALIBRATION_DATA_SAVE(x) \
-    saved_struct_save(           \
-        CALIBRATION_DATA_PATH,   \
-        (x),                     \
+#define CALIBRATION_DATA_SAVE(x)   \
+    saved_struct_save(             \
+        CALIBRATION_DATA_PATH,     \
+        (x),                       \
         sizeof(CalibrationMedian), \
-        CALIBRATION_DATA_MAGIC,  \
+        CALIBRATION_DATA_MAGIC,    \
         CALIBRATION_DATA_VER)
 
-#define CALIBRATION_DATA_LOAD(x) \
-    saved_struct_load(           \
-        CALIBRATION_DATA_PATH,   \
-        (x),                     \
+#define CALIBRATION_DATA_LOAD(x)   \
+    saved_struct_load(             \
+        CALIBRATION_DATA_PATH,     \
+        (x),                       \
         sizeof(CalibrationMedian), \
-        CALIBRATION_DATA_MAGIC,  \
+        CALIBRATION_DATA_MAGIC,    \
         CALIBRATION_DATA_VER)
 
 typedef struct {
@@ -41,14 +41,15 @@ typedef cardboard::Vector3 Vector;
  * filing bugs), other may be required in the future, e.g. for bias.
  */
 class CalibrationData {
-
 public:
     /**
      * Check if the sensors were calibrated before.
      *
      * @return {@code true} if calibration data is available, or {@code false} otherwise.
      */
-    bool isComplete() { return complete; }
+    bool isComplete() {
+        return complete;
+    }
 
     /** Prepare to collect new calibration data. */
     void reset();
@@ -58,28 +59,36 @@ public:
      *
      * @return Three-axis median vector.
      */
-    Vector getMedian() { return median; }
+    Vector getMedian() {
+        return median;
+    }
 
     /**
      * Retrieve the mean gyroscope readings.
      *
      * @return Three-axis mean vector.
      */
-    Vector getMean() { return mean; }
+    Vector getMean() {
+        return mean;
+    }
 
     /**
      * Retrieve the standard deviation of gyroscope readings.
      *
      * @return Three-axis standard deviation vector.
      */
-    Vector getSigma() { return sigma; }
+    Vector getSigma() {
+        return sigma;
+    }
 
     /**
      * Retrieve the confidence interval size of gyroscope readings.
      *
      * @return Three-axis confidence interval size vector.
      */
-    Vector getDelta() { return delta; }
+    Vector getDelta() {
+        return delta;
+    }
 
     /**
      * Add a new gyroscope reading to the stats.

Разница между файлами не показана из-за своего большого размера
+ 226 - 149
tracking/imu/bmi160.c


+ 64 - 41
tracking/imu/bmi160.h

@@ -82,7 +82,7 @@ extern "C" {
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_init(struct bmi160_dev *dev);
+int8_t bmi160_init(struct bmi160_dev* dev);
 
 /**
  * \ingroup bmi160
@@ -111,7 +111,8 @@ int8_t bmi160_init(struct bmi160_dev *dev);
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_get_regs(uint8_t reg_addr, uint8_t *data, uint16_t len, const struct bmi160_dev *dev);
+int8_t
+    bmi160_get_regs(uint8_t reg_addr, uint8_t* data, uint16_t len, const struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiRegs
@@ -132,7 +133,8 @@ int8_t bmi160_get_regs(uint8_t reg_addr, uint8_t *data, uint16_t len, const stru
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_set_regs(uint8_t reg_addr, uint8_t *data, uint16_t len, const struct bmi160_dev *dev);
+int8_t
+    bmi160_set_regs(uint8_t reg_addr, uint8_t* data, uint16_t len, const struct bmi160_dev* dev);
 
 /**
  * \ingroup bmi160
@@ -155,7 +157,7 @@ int8_t bmi160_set_regs(uint8_t reg_addr, uint8_t *data, uint16_t len, const stru
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_soft_reset(struct bmi160_dev *dev);
+int8_t bmi160_soft_reset(struct bmi160_dev* dev);
 
 /**
  * \ingroup bmi160
@@ -179,7 +181,7 @@ int8_t bmi160_soft_reset(struct bmi160_dev *dev);
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_set_sens_conf(struct bmi160_dev *dev);
+int8_t bmi160_set_sens_conf(struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiConfig
@@ -196,7 +198,7 @@ int8_t bmi160_set_sens_conf(struct bmi160_dev *dev);
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_get_sens_conf(struct bmi160_dev *dev);
+int8_t bmi160_get_sens_conf(struct bmi160_dev* dev);
 
 /**
  * \ingroup bmi160
@@ -218,7 +220,7 @@ int8_t bmi160_get_sens_conf(struct bmi160_dev *dev);
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_set_power_mode(struct bmi160_dev *dev);
+int8_t bmi160_set_power_mode(struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiPowermode
@@ -234,7 +236,7 @@ int8_t bmi160_set_power_mode(struct bmi160_dev *dev);
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_get_power_mode(struct bmi160_dev *dev);
+int8_t bmi160_get_power_mode(struct bmi160_dev* dev);
 
 /**
  * \ingroup bmi160
@@ -267,10 +269,11 @@ int8_t bmi160_get_power_mode(struct bmi160_dev *dev);
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_get_sensor_data(uint8_t select_sensor,
-                              struct bmi160_sensor_data *accel,
-                              struct bmi160_sensor_data *gyro,
-                              const struct bmi160_dev *dev);
+int8_t bmi160_get_sensor_data(
+    uint8_t select_sensor,
+    struct bmi160_sensor_data* accel,
+    struct bmi160_sensor_data* gyro,
+    const struct bmi160_dev* dev);
 
 /**
  * \ingroup bmi160
@@ -295,7 +298,7 @@ int8_t bmi160_get_sensor_data(uint8_t select_sensor,
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_set_int_config(struct bmi160_int_settg *int_config, struct bmi160_dev *dev);
+int8_t bmi160_set_int_config(struct bmi160_int_settg* int_config, struct bmi160_dev* dev);
 
 /**
  * \ingroup bmi160
@@ -319,7 +322,7 @@ int8_t bmi160_set_int_config(struct bmi160_int_settg *int_config, struct bmi160_
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_set_step_counter(uint8_t step_cnt_enable, const struct bmi160_dev *dev);
+int8_t bmi160_set_step_counter(uint8_t step_cnt_enable, const struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiStepC
@@ -337,7 +340,7 @@ int8_t bmi160_set_step_counter(uint8_t step_cnt_enable, const struct bmi160_dev
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_read_step_counter(uint16_t *step_val, const struct bmi160_dev *dev);
+int8_t bmi160_read_step_counter(uint16_t* step_val, const struct bmi160_dev* dev);
 
 /**
  * \ingroup bmi160
@@ -364,7 +367,11 @@ int8_t bmi160_read_step_counter(uint16_t *step_val, const struct bmi160_dev *dev
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_aux_read(uint8_t reg_addr, uint8_t *aux_data, uint16_t len, const struct bmi160_dev *dev);
+int8_t bmi160_aux_read(
+    uint8_t reg_addr,
+    uint8_t* aux_data,
+    uint16_t len,
+    const struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiAux
@@ -385,7 +392,11 @@ int8_t bmi160_aux_read(uint8_t reg_addr, uint8_t *aux_data, uint16_t len, const
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_aux_write(uint8_t reg_addr, uint8_t *aux_data, uint16_t len, const struct bmi160_dev *dev);
+int8_t bmi160_aux_write(
+    uint8_t reg_addr,
+    uint8_t* aux_data,
+    uint16_t len,
+    const struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiAux
@@ -403,7 +414,7 @@ int8_t bmi160_aux_write(uint8_t reg_addr, uint8_t *aux_data, uint16_t len, const
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_aux_init(const struct bmi160_dev *dev);
+int8_t bmi160_aux_init(const struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiAux
@@ -447,7 +458,7 @@ int8_t bmi160_aux_init(const struct bmi160_dev *dev);
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_set_aux_auto_mode(uint8_t *data_addr, struct bmi160_dev *dev);
+int8_t bmi160_set_aux_auto_mode(uint8_t* data_addr, struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiAux
@@ -464,7 +475,7 @@ int8_t bmi160_set_aux_auto_mode(uint8_t *data_addr, struct bmi160_dev *dev);
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_config_aux_mode(const struct bmi160_dev *dev);
+int8_t bmi160_config_aux_mode(const struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiAux
@@ -484,7 +495,7 @@ int8_t bmi160_config_aux_mode(const struct bmi160_dev *dev);
  * @retval Zero Success
  * @retval Negative Error
  */
-int8_t bmi160_read_aux_data_auto_mode(uint8_t *aux_data, const struct bmi160_dev *dev);
+int8_t bmi160_read_aux_data_auto_mode(uint8_t* aux_data, const struct bmi160_dev* dev);
 
 /**
  * \ingroup bmi160
@@ -523,7 +534,7 @@ int8_t bmi160_read_aux_data_auto_mode(uint8_t *aux_data, const struct bmi160_dev
  * @retval  BMI160_W_GYRO_SELF_TEST_FAIL    Gyro self test fail
  * @retval  BMI160_W_ACCEl_SELF_TEST_FAIL   Accel self test fail
  */
-int8_t bmi160_perform_self_test(uint8_t select_sensor, struct bmi160_dev *dev);
+int8_t bmi160_perform_self_test(uint8_t select_sensor, struct bmi160_dev* dev);
 
 /**
  * \ingroup bmi160
@@ -553,7 +564,7 @@ int8_t bmi160_perform_self_test(uint8_t select_sensor, struct bmi160_dev *dev);
  *  @retval Zero Success
  *  @retval Negative Error
  */
-int8_t bmi160_get_fifo_data(struct bmi160_dev const *dev);
+int8_t bmi160_get_fifo_data(struct bmi160_dev const* dev);
 
 /*!
  * \ingroup bmi160ApiFIFO
@@ -572,7 +583,7 @@ int8_t bmi160_get_fifo_data(struct bmi160_dev const *dev);
  *  @retval Any non zero value -> Fail
  *
  */
-int8_t bmi160_set_fifo_flush(const struct bmi160_dev *dev);
+int8_t bmi160_set_fifo_flush(const struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiFIFO
@@ -609,7 +620,7 @@ int8_t bmi160_set_fifo_flush(const struct bmi160_dev *dev);
  *  @retval Any non zero value -> Fail
  *
  */
-int8_t bmi160_set_fifo_config(uint8_t config, uint8_t enable, struct bmi160_dev const *dev);
+int8_t bmi160_set_fifo_config(uint8_t config, uint8_t enable, struct bmi160_dev const* dev);
 
 /*!
  * \ingroup bmi160ApiFIFO
@@ -682,7 +693,7 @@ int8_t bmi160_set_fifo_config(uint8_t config, uint8_t enable, struct bmi160_dev
  *  @retval Any non zero value -> Fail
  *
  */
-int8_t bmi160_set_fifo_down(uint8_t fifo_down, const struct bmi160_dev *dev);
+int8_t bmi160_set_fifo_down(uint8_t fifo_down, const struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiFIFO
@@ -703,7 +714,7 @@ int8_t bmi160_set_fifo_down(uint8_t fifo_down, const struct bmi160_dev *dev);
  *  @retval Any non zero value -> Fail
  *
  */
-int8_t bmi160_set_fifo_wm(uint8_t fifo_wm, const struct bmi160_dev *dev);
+int8_t bmi160_set_fifo_wm(uint8_t fifo_wm, const struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiFIFO
@@ -734,7 +745,10 @@ int8_t bmi160_set_fifo_wm(uint8_t fifo_wm, const struct bmi160_dev *dev);
  *  @retval Any non zero value -> Fail
  *
  */
-int8_t bmi160_extract_accel(struct bmi160_sensor_data *accel_data, uint8_t *accel_length, struct bmi160_dev const *dev);
+int8_t bmi160_extract_accel(
+    struct bmi160_sensor_data* accel_data,
+    uint8_t* accel_length,
+    struct bmi160_dev const* dev);
 
 /*!
  * \ingroup bmi160ApiFIFO
@@ -764,7 +778,10 @@ int8_t bmi160_extract_accel(struct bmi160_sensor_data *accel_data, uint8_t *acce
  *  @retval Any non zero value -> Fail
  *
  */
-int8_t bmi160_extract_gyro(struct bmi160_sensor_data *gyro_data, uint8_t *gyro_length, struct bmi160_dev const *dev);
+int8_t bmi160_extract_gyro(
+    struct bmi160_sensor_data* gyro_data,
+    uint8_t* gyro_length,
+    struct bmi160_dev const* dev);
 
 /*!
  * \ingroup bmi160ApiFIFO
@@ -794,7 +811,10 @@ int8_t bmi160_extract_gyro(struct bmi160_sensor_data *gyro_data, uint8_t *gyro_l
  *  @retval Any non zero value -> Fail
  *
  */
-int8_t bmi160_extract_aux(struct bmi160_aux_data *aux_data, uint8_t *aux_len, struct bmi160_dev const *dev);
+int8_t bmi160_extract_aux(
+    struct bmi160_aux_data* aux_data,
+    uint8_t* aux_len,
+    struct bmi160_dev const* dev);
 
 /**
  * \ingroup bmi160
@@ -846,9 +866,10 @@ int8_t bmi160_extract_aux(struct bmi160_aux_data *aux_data, uint8_t *aux_len, st
  *  @retval 0 -> Success
  *  @retval Any non zero value -> Fail
  */
-int8_t bmi160_start_foc(const struct bmi160_foc_conf *foc_conf,
-                        struct bmi160_offsets *offset,
-                        struct bmi160_dev const *dev);
+int8_t bmi160_start_foc(
+    const struct bmi160_foc_conf* foc_conf,
+    struct bmi160_offsets* offset,
+    struct bmi160_dev const* dev);
 
 /**
  * \ingroup bmi160
@@ -872,7 +893,7 @@ int8_t bmi160_start_foc(const struct bmi160_foc_conf *foc_conf,
  *  @retval 0 -> Success
  *  @retval Any non zero value -> Fail
  */
-int8_t bmi160_get_offsets(struct bmi160_offsets *offset, const struct bmi160_dev *dev);
+int8_t bmi160_get_offsets(struct bmi160_offsets* offset, const struct bmi160_dev* dev);
 
 /*!
  * \ingroup bmi160ApiOffsets
@@ -904,9 +925,10 @@ int8_t bmi160_get_offsets(struct bmi160_offsets *offset, const struct bmi160_dev
  *  @retval 0 -> Success
  *  @retval Any non zero value -> Fail
  */
-int8_t bmi160_set_offsets(const struct bmi160_foc_conf *foc_conf,
-                          const struct bmi160_offsets *offset,
-                          struct bmi160_dev const *dev);
+int8_t bmi160_set_offsets(
+    const struct bmi160_foc_conf* foc_conf,
+    const struct bmi160_offsets* offset,
+    struct bmi160_dev const* dev);
 
 /**
  * \ingroup bmi160
@@ -929,7 +951,7 @@ int8_t bmi160_set_offsets(const struct bmi160_foc_conf *foc_conf,
  *  @retval 0 -> Success
  *  @retval Any non zero value -> Fail
  */
-int8_t bmi160_update_nvm(struct bmi160_dev const *dev);
+int8_t bmi160_update_nvm(struct bmi160_dev const* dev);
 
 /**
  * \ingroup bmi160
@@ -957,9 +979,10 @@ int8_t bmi160_update_nvm(struct bmi160_dev const *dev);
  *  @retval 0 -> Success
  *  @retval Any non zero value -> Fail
  */
-int8_t bmi160_get_int_status(enum bmi160_int_status_sel int_status_sel,
-                             union bmi160_int_status *int_status,
-                             struct bmi160_dev const *dev);
+int8_t bmi160_get_int_status(
+    enum bmi160_int_status_sel int_status_sel,
+    union bmi160_int_status* int_status,
+    struct bmi160_dev const* dev);
 
 /*************************** C++ guard macro *****************************/
 #ifdef __cplusplus

Разница между файлами не показана из-за своего большого размера
+ 441 - 444
tracking/imu/bmi160_defs.h


+ 1 - 1
tracking/imu/imu.c

@@ -17,7 +17,7 @@ bool imu_begin() {
 
 void imu_end() {
     furi_hal_i2c_acquire(&furi_hal_i2c_handle_external);
-    lsm6ds3trc_end(); // 
+    lsm6ds3trc_end(); //
     furi_hal_i2c_release(&furi_hal_i2c_handle_external);
 }
 

+ 11 - 9
tracking/imu/imu_bmi160.c

@@ -6,7 +6,7 @@
 
 #define TAG "BMI160"
 
-#define BMI160_DEV_ADDR       (0x69 << 1)
+#define BMI160_DEV_ADDR (0x69 << 1)
 
 static const double DEG_TO_RAD = 0.017453292519943295769236907684886;
 static const double G = 9.81;
@@ -15,14 +15,14 @@ struct bmi160_dev bmi160dev;
 struct bmi160_sensor_data bmi160_accel;
 struct bmi160_sensor_data bmi160_gyro;
 
-int8_t bmi160_write_i2c(uint8_t dev_addr, uint8_t reg_addr, uint8_t *data, uint16_t len) {
-    if (furi_hal_i2c_write_mem(&furi_hal_i2c_handle_external, dev_addr, reg_addr, data, len, 50))
+int8_t bmi160_write_i2c(uint8_t dev_addr, uint8_t reg_addr, uint8_t* data, uint16_t len) {
+    if(furi_hal_i2c_write_mem(&furi_hal_i2c_handle_external, dev_addr, reg_addr, data, len, 50))
         return BMI160_OK;
     return BMI160_E_COM_FAIL;
 }
 
-int8_t bmi160_read_i2c(uint8_t dev_addr, uint8_t reg_addr, uint8_t *read_data, uint16_t len) {
-    if (furi_hal_i2c_read_mem(&furi_hal_i2c_handle_external, dev_addr, reg_addr, read_data, len, 50))
+int8_t bmi160_read_i2c(uint8_t dev_addr, uint8_t reg_addr, uint8_t* read_data, uint16_t len) {
+    if(furi_hal_i2c_read_mem(&furi_hal_i2c_handle_external, dev_addr, reg_addr, read_data, len, 50))
         return BMI160_OK;
     return BMI160_E_COM_FAIL;
 }
@@ -30,7 +30,7 @@ int8_t bmi160_read_i2c(uint8_t dev_addr, uint8_t reg_addr, uint8_t *read_data, u
 bool bmi160_begin() {
     FURI_LOG_I(TAG, "Init BMI160");
 
-    if (!furi_hal_i2c_is_device_ready(&furi_hal_i2c_handle_external, BMI160_DEV_ADDR, 50)) {
+    if(!furi_hal_i2c_is_device_ready(&furi_hal_i2c_handle_external, BMI160_DEV_ADDR, 50)) {
         FURI_LOG_E(TAG, "Device not ready!");
         return false;
     }
@@ -43,7 +43,7 @@ bool bmi160_begin() {
     bmi160dev.write = bmi160_write_i2c;
     bmi160dev.delay_ms = furi_delay_ms;
 
-    if (bmi160_init(&bmi160dev) != BMI160_OK) {
+    if(bmi160_init(&bmi160dev) != BMI160_OK) {
         FURI_LOG_E(TAG, "Initialization failure!");
         FURI_LOG_E(TAG, "Chip ID 0x%X", bmi160dev.chip_id);
         return false;
@@ -58,7 +58,7 @@ bool bmi160_begin() {
     bmi160dev.gyro_cfg.bw = BMI160_GYRO_BW_NORMAL_MODE;
     bmi160dev.gyro_cfg.power = BMI160_GYRO_NORMAL_MODE;
 
-    if (bmi160_set_sens_conf(&bmi160dev) != BMI160_OK) {
+    if(bmi160_set_sens_conf(&bmi160dev) != BMI160_OK) {
         FURI_LOG_E(TAG, "Initialization failure!");
         FURI_LOG_E(TAG, "Chip ID 0x%X", bmi160dev.chip_id);
         return false;
@@ -71,7 +71,9 @@ bool bmi160_begin() {
 }
 
 int bmi160_read(float* vec) {
-    if (bmi160_get_sensor_data((BMI160_ACCEL_SEL | BMI160_GYRO_SEL), &bmi160_accel, &bmi160_gyro, &bmi160dev) != BMI160_OK) {
+    if(bmi160_get_sensor_data(
+           (BMI160_ACCEL_SEL | BMI160_GYRO_SEL), &bmi160_accel, &bmi160_gyro, &bmi160dev) !=
+       BMI160_OK) {
         return 0;
     }
 

+ 11 - 13
tracking/imu/imu_lsm6ds3trc.c

@@ -1,4 +1,4 @@
-#include "lsm6ds3tr-c_reg.h"
+#include "lsm6ds3tr_c_reg.h"
 
 #include <furi_hal.h>
 
@@ -6,28 +6,27 @@
 
 #define TAG "LSM6DS3TR-C"
 
-#define LSM6DS3_ADDRESS            (0x6A << 1)
+#define LSM6DS3_ADDRESS (0x6A << 1)
 
 static const double DEG_TO_RAD = 0.017453292519943295769236907684886;
 
 stmdev_ctx_t lsm6ds3trc_ctx;
 
-int32_t lsm6ds3trc_write_i2c(void *handle, uint8_t reg_addr, const uint8_t *data, uint16_t len) {
-    if (furi_hal_i2c_write_mem(handle, LSM6DS3_ADDRESS, reg_addr, (uint8_t *)data, len, 50))
+int32_t lsm6ds3trc_write_i2c(void* handle, uint8_t reg_addr, const uint8_t* data, uint16_t len) {
+    if(furi_hal_i2c_write_mem(handle, LSM6DS3_ADDRESS, reg_addr, (uint8_t*)data, len, 50))
         return 0;
     return -1;
 }
 
-int32_t lsm6ds3trc_read_i2c(void *handle, uint8_t reg_addr, uint8_t *read_data, uint16_t len) {
-    if (furi_hal_i2c_read_mem(handle, LSM6DS3_ADDRESS, reg_addr, read_data, len, 50))
-        return 0;
+int32_t lsm6ds3trc_read_i2c(void* handle, uint8_t reg_addr, uint8_t* read_data, uint16_t len) {
+    if(furi_hal_i2c_read_mem(handle, LSM6DS3_ADDRESS, reg_addr, read_data, len, 50)) return 0;
     return -1;
 }
 
 bool lsm6ds3trc_begin() {
     FURI_LOG_I(TAG, "Init LSM6DS3TR-C");
 
-    if (!furi_hal_i2c_is_device_ready(&furi_hal_i2c_handle_external, LSM6DS3_ADDRESS, 50)) {
+    if(!furi_hal_i2c_is_device_ready(&furi_hal_i2c_handle_external, LSM6DS3_ADDRESS, 50)) {
         FURI_LOG_E(TAG, "Not ready");
         return false;
     }
@@ -39,15 +38,14 @@ bool lsm6ds3trc_begin() {
 
     uint8_t whoami;
     lsm6ds3tr_c_device_id_get(&lsm6ds3trc_ctx, &whoami);
-    if (whoami != LSM6DS3TR_C_ID) {
+    if(whoami != LSM6DS3TR_C_ID) {
         FURI_LOG_I(TAG, "Unknown model: %x", (int)whoami);
         return false;
     }
 
     lsm6ds3tr_c_reset_set(&lsm6ds3trc_ctx, PROPERTY_ENABLE);
     uint8_t rst = PROPERTY_ENABLE;
-    while (rst)
-        lsm6ds3tr_c_reset_get(&lsm6ds3trc_ctx, &rst);
+    while(rst) lsm6ds3tr_c_reset_get(&lsm6ds3trc_ctx, &rst);
 
     lsm6ds3tr_c_block_data_update_set(&lsm6ds3trc_ctx, PROPERTY_ENABLE);
     lsm6ds3tr_c_fifo_mode_set(&lsm6ds3trc_ctx, LSM6DS3TR_C_BYPASS_MODE);
@@ -76,7 +74,7 @@ int lsm6ds3trc_read(double* vec) {
     lsm6ds3tr_c_reg_t reg;
     lsm6ds3tr_c_status_reg_get(&lsm6ds3trc_ctx, &reg.status_reg);
 
-    if (reg.status_reg.xlda) {
+    if(reg.status_reg.xlda) {
         lsm6ds3tr_c_acceleration_raw_get(&lsm6ds3trc_ctx, data);
         vec[0] = (double)lsm6ds3tr_c_from_fs2g_to_mg(data[0]) / 1000;
         vec[1] = (double)lsm6ds3tr_c_from_fs2g_to_mg(data[1]) / 1000;
@@ -84,7 +82,7 @@ int lsm6ds3trc_read(double* vec) {
         ret |= ACC_DATA_READY;
     }
 
-    if (reg.status_reg.gda) {
+    if(reg.status_reg.gda) {
         lsm6ds3tr_c_angular_rate_raw_get(&lsm6ds3trc_ctx, data);
         vec[3] = (double)lsm6ds3tr_c_from_fs2000dps_to_mdps(data[0]) * DEG_TO_RAD / 1000;
         vec[4] = (double)lsm6ds3tr_c_from_fs2000dps_to_mdps(data[1]) * DEG_TO_RAD / 1000;

+ 0 - 8209
tracking/imu/lsm6ds3tr-c_reg.c

@@ -1,8209 +0,0 @@
-/**
-  ******************************************************************************
-  * @file    lsm6ds3tr_c_reg.c
-  * @author  Sensors Software Solution Team
-  * @brief   LSM6DS3TR_C driver file
-  ******************************************************************************
-  * @attention
-  *
-  * <h2><center>&copy; Copyright (c) 2021 STMicroelectronics.
-  * All rights reserved.</center></h2>
-  *
-  * This software component is licensed by ST under BSD 3-Clause license,
-  * the "License"; You may not use this file except in compliance with the
-  * License. You may obtain a copy of the License at:
-  *                        opensource.org/licenses/BSD-3-Clause
-  *
-  ******************************************************************************
-  */
-
-#include "lsm6ds3tr-c_reg.h"
-
-/**
-  * @defgroup    LSM6DS3TR_C
-  * @brief       This file provides a set of functions needed to drive the
-  *              lsm6ds3tr_c enanced inertial module.
-  * @{
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_interfaces_functions
-  * @brief       This section provide a set of functions used to read and
-  *              write a generic register of the device.
-  *              MANDATORY: return 0 -> no Error.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Read generic device register
-  *
-  * @param  ctx   read / write interface definitions(ptr)
-  * @param  reg   register to read
-  * @param  data  pointer to buffer that store the data read(ptr)
-  * @param  len   number of consecutive register to read
-  * @retval       interface status (MANDATORY: return 0 -> no Error)
-  *
-  */
-int32_t lsm6ds3tr_c_read_reg(stmdev_ctx_t *ctx, uint8_t reg,
-                             uint8_t *data,
-                             uint16_t len)
-{
-  int32_t ret;
-
-  ret = ctx->read_reg(ctx->handle, reg, data, len);
-
-  return ret;
-}
-
-/**
-  * @brief  Write generic device register
-  *
-  * @param  ctx   read / write interface definitions(ptr)
-  * @param  reg   register to write
-  * @param  data  pointer to data to write in register reg(ptr)
-  * @param  len   number of consecutive register to write
-  * @retval       interface status (MANDATORY: return 0 -> no Error)
-  *
-  */
-int32_t lsm6ds3tr_c_write_reg(stmdev_ctx_t *ctx, uint8_t reg,
-                              uint8_t *data,
-                              uint16_t len)
-{
-  int32_t ret;
-
-  ret = ctx->write_reg(ctx->handle, reg, data, len);
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_Sensitivity
-  * @brief       These functions convert raw-data into engineering units.
-  * @{
-  *
-  */
-
-float_t lsm6ds3tr_c_from_fs2g_to_mg(int16_t lsb)
-{
-  return ((float_t)lsb * 0.061f);
-}
-
-float_t lsm6ds3tr_c_from_fs4g_to_mg(int16_t lsb)
-{
-  return ((float_t)lsb * 0.122f);
-}
-
-float_t lsm6ds3tr_c_from_fs8g_to_mg(int16_t lsb)
-{
-  return ((float_t)lsb * 0.244f);
-}
-
-float_t lsm6ds3tr_c_from_fs16g_to_mg(int16_t lsb)
-{
-  return ((float_t)lsb * 0.488f);
-}
-
-float_t lsm6ds3tr_c_from_fs125dps_to_mdps(int16_t lsb)
-{
-  return ((float_t)lsb * 4.375f);
-}
-
-float_t lsm6ds3tr_c_from_fs250dps_to_mdps(int16_t lsb)
-{
-  return ((float_t)lsb * 8.750f);
-}
-
-float_t lsm6ds3tr_c_from_fs500dps_to_mdps(int16_t lsb)
-{
-  return ((float_t)lsb * 17.50f);
-}
-
-float_t lsm6ds3tr_c_from_fs1000dps_to_mdps(int16_t lsb)
-{
-  return ((float_t)lsb * 35.0f);
-}
-
-float_t lsm6ds3tr_c_from_fs2000dps_to_mdps(int16_t lsb)
-{
-  return ((float_t)lsb * 70.0f);
-}
-
-float_t lsm6ds3tr_c_from_lsb_to_celsius(int16_t lsb)
-{
-  return (((float_t)lsb / 256.0f) + 25.0f);
-}
-
-/**
-  * @}
-  *
-  */
-
-
-/**
-  * @defgroup    LSM6DS3TR_C_data_generation
-  * @brief       This section groups all the functions concerning data
-  *              generation
-  * @{
-  *
-  */
-
-/**
-  * @brief  Accelerometer full-scale selection.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of fs_xl in reg CTRL1_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_full_scale_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_fs_xl_t val)
-{
-  lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                             (uint8_t *)&ctrl1_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl1_xl.fs_xl = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                                (uint8_t *)&ctrl1_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Accelerometer full-scale selection.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of fs_xl in reg CTRL1_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_full_scale_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_fs_xl_t *val)
-{
-  lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                             (uint8_t *)&ctrl1_xl, 1);
-
-  switch (ctrl1_xl.fs_xl)
-  {
-    case LSM6DS3TR_C_2g:
-      *val = LSM6DS3TR_C_2g;
-      break;
-
-    case LSM6DS3TR_C_16g:
-      *val = LSM6DS3TR_C_16g;
-      break;
-
-    case LSM6DS3TR_C_4g:
-      *val = LSM6DS3TR_C_4g;
-      break;
-
-    case LSM6DS3TR_C_8g:
-      *val = LSM6DS3TR_C_8g;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_XL_FS_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Accelerometer data rate selection.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of odr_xl in reg CTRL1_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_data_rate_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_odr_xl_t val)
-{
-  lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                             (uint8_t *)&ctrl1_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl1_xl.odr_xl = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                                (uint8_t *)&ctrl1_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Accelerometer data rate selection.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of odr_xl in reg CTRL1_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_data_rate_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_odr_xl_t *val)
-{
-  lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                             (uint8_t *)&ctrl1_xl, 1);
-
-  switch (ctrl1_xl.odr_xl)
-  {
-    case LSM6DS3TR_C_XL_ODR_OFF:
-      *val = LSM6DS3TR_C_XL_ODR_OFF;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_12Hz5:
-      *val = LSM6DS3TR_C_XL_ODR_12Hz5;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_26Hz:
-      *val = LSM6DS3TR_C_XL_ODR_26Hz;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_52Hz:
-      *val = LSM6DS3TR_C_XL_ODR_52Hz;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_104Hz:
-      *val = LSM6DS3TR_C_XL_ODR_104Hz;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_208Hz:
-      *val = LSM6DS3TR_C_XL_ODR_208Hz;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_416Hz:
-      *val = LSM6DS3TR_C_XL_ODR_416Hz;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_833Hz:
-      *val = LSM6DS3TR_C_XL_ODR_833Hz;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_1k66Hz:
-      *val = LSM6DS3TR_C_XL_ODR_1k66Hz;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_3k33Hz:
-      *val = LSM6DS3TR_C_XL_ODR_3k33Hz;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_6k66Hz:
-      *val = LSM6DS3TR_C_XL_ODR_6k66Hz;
-      break;
-
-    case LSM6DS3TR_C_XL_ODR_1Hz6:
-      *val = LSM6DS3TR_C_XL_ODR_1Hz6;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_XL_ODR_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Gyroscope chain full-scale selection.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of fs_g in reg CTRL2_G
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_full_scale_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_fs_g_t val)
-{
-  lsm6ds3tr_c_ctrl2_g_t ctrl2_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL2_G,
-                             (uint8_t *)&ctrl2_g, 1);
-
-  if (ret == 0)
-  {
-    ctrl2_g.fs_g = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL2_G,
-                                (uint8_t *)&ctrl2_g, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Gyroscope chain full-scale selection.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of fs_g in reg CTRL2_G
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_full_scale_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_fs_g_t *val)
-{
-  lsm6ds3tr_c_ctrl2_g_t ctrl2_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL2_G,
-                             (uint8_t *)&ctrl2_g, 1);
-
-  switch (ctrl2_g.fs_g)
-  {
-    case LSM6DS3TR_C_250dps:
-      *val = LSM6DS3TR_C_250dps;
-      break;
-
-    case LSM6DS3TR_C_125dps:
-      *val = LSM6DS3TR_C_125dps;
-      break;
-
-    case LSM6DS3TR_C_500dps:
-      *val = LSM6DS3TR_C_500dps;
-      break;
-
-    case LSM6DS3TR_C_1000dps:
-      *val = LSM6DS3TR_C_1000dps;
-      break;
-
-    case LSM6DS3TR_C_2000dps:
-      *val = LSM6DS3TR_C_2000dps;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_GY_FS_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Gyroscope data rate selection.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of odr_g in reg CTRL2_G
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_data_rate_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_odr_g_t val)
-{
-  lsm6ds3tr_c_ctrl2_g_t ctrl2_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL2_G,
-                             (uint8_t *)&ctrl2_g, 1);
-
-  if (ret == 0)
-  {
-    ctrl2_g.odr_g = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL2_G,
-                                (uint8_t *)&ctrl2_g, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Gyroscope data rate selection.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of odr_g in reg CTRL2_G
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_data_rate_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_odr_g_t *val)
-{
-  lsm6ds3tr_c_ctrl2_g_t ctrl2_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL2_G,
-                             (uint8_t *)&ctrl2_g, 1);
-
-  switch (ctrl2_g.odr_g)
-  {
-    case LSM6DS3TR_C_GY_ODR_OFF:
-      *val = LSM6DS3TR_C_GY_ODR_OFF;
-      break;
-
-    case LSM6DS3TR_C_GY_ODR_12Hz5:
-      *val = LSM6DS3TR_C_GY_ODR_12Hz5;
-      break;
-
-    case LSM6DS3TR_C_GY_ODR_26Hz:
-      *val = LSM6DS3TR_C_GY_ODR_26Hz;
-      break;
-
-    case LSM6DS3TR_C_GY_ODR_52Hz:
-      *val = LSM6DS3TR_C_GY_ODR_52Hz;
-      break;
-
-    case LSM6DS3TR_C_GY_ODR_104Hz:
-      *val = LSM6DS3TR_C_GY_ODR_104Hz;
-      break;
-
-    case LSM6DS3TR_C_GY_ODR_208Hz:
-      *val = LSM6DS3TR_C_GY_ODR_208Hz;
-      break;
-
-    case LSM6DS3TR_C_GY_ODR_416Hz:
-      *val = LSM6DS3TR_C_GY_ODR_416Hz;
-      break;
-
-    case LSM6DS3TR_C_GY_ODR_833Hz:
-      *val = LSM6DS3TR_C_GY_ODR_833Hz;
-      break;
-
-    case LSM6DS3TR_C_GY_ODR_1k66Hz:
-      *val = LSM6DS3TR_C_GY_ODR_1k66Hz;
-      break;
-
-    case LSM6DS3TR_C_GY_ODR_3k33Hz:
-      *val = LSM6DS3TR_C_GY_ODR_3k33Hz;
-      break;
-
-    case LSM6DS3TR_C_GY_ODR_6k66Hz:
-      *val = LSM6DS3TR_C_GY_ODR_6k66Hz;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_GY_ODR_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Block data update.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of bdu in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_block_data_update_set(stmdev_ctx_t *ctx,
-                                          uint8_t val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl3_c.bdu = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                                (uint8_t *)&ctrl3_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Block data update.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of bdu in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_block_data_update_get(stmdev_ctx_t *ctx,
-                                          uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-  *val = ctrl3_c.bdu;
-
-  return ret;
-}
-
-/**
-  * @brief  Weight of XL user offset bits of registers
-  *         X_OFS_USR(73h), Y_OFS_USR(74h), Z_OFS_USR(75h).[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of usr_off_w in reg CTRL6_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_offset_weight_set(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_usr_off_w_t val)
-{
-  lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                             (uint8_t *)&ctrl6_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl6_c.usr_off_w = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                                (uint8_t *)&ctrl6_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Weight of XL user offset bits of registers
-  *         X_OFS_USR(73h), Y_OFS_USR(74h), Z_OFS_USR(75h).[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of usr_off_w in reg CTRL6_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_offset_weight_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_usr_off_w_t *val)
-{
-  lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                             (uint8_t *)&ctrl6_c, 1);
-
-  switch (ctrl6_c.usr_off_w)
-  {
-    case LSM6DS3TR_C_LSb_1mg:
-      *val = LSM6DS3TR_C_LSb_1mg;
-      break;
-
-    case LSM6DS3TR_C_LSb_16mg:
-      *val = LSM6DS3TR_C_LSb_16mg;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_WEIGHT_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  High-performance operating mode for accelerometer[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of xl_hm_mode in reg CTRL6_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_power_mode_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_xl_hm_mode_t val)
-{
-  lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                             (uint8_t *)&ctrl6_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl6_c.xl_hm_mode = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                                (uint8_t *)&ctrl6_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  High-performance operating mode for accelerometer.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of xl_hm_mode in reg CTRL6_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_power_mode_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_xl_hm_mode_t *val)
-{
-  lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                             (uint8_t *)&ctrl6_c, 1);
-
-  switch (ctrl6_c.xl_hm_mode)
-  {
-    case LSM6DS3TR_C_XL_HIGH_PERFORMANCE:
-      *val = LSM6DS3TR_C_XL_HIGH_PERFORMANCE;
-      break;
-
-    case LSM6DS3TR_C_XL_NORMAL:
-      *val = LSM6DS3TR_C_XL_NORMAL;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_XL_PW_MODE_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Source register rounding function on WAKE_UP_SRC (1Bh),
-  *         TAP_SRC (1Ch), D6D_SRC (1Dh), STATUS_REG (1Eh) and
-  *         FUNC_SRC1 (53h) registers in the primary interface.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of rounding_status in reg CTRL7_G
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_rounding_on_status_set(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_rounding_status_t val)
-{
-  lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G,
-                             (uint8_t *)&ctrl7_g, 1);
-
-  if (ret == 0)
-  {
-    ctrl7_g.rounding_status = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL7_G,
-                                (uint8_t *)&ctrl7_g, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Source register rounding function on WAKE_UP_SRC (1Bh),
-  *         TAP_SRC (1Ch), D6D_SRC (1Dh), STATUS_REG (1Eh) and
-  *         FUNC_SRC1 (53h) registers in the primary interface.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of rounding_status in reg CTRL7_G
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_rounding_on_status_get(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_rounding_status_t *val)
-{
-  lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G,
-                             (uint8_t *)&ctrl7_g, 1);
-
-  switch (ctrl7_g.rounding_status)
-  {
-    case LSM6DS3TR_C_STAT_RND_DISABLE:
-      *val = LSM6DS3TR_C_STAT_RND_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_STAT_RND_ENABLE:
-      *val = LSM6DS3TR_C_STAT_RND_ENABLE;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_STAT_RND_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  High-performance operating mode disable for gyroscope.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of g_hm_mode in reg CTRL7_G
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_power_mode_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_g_hm_mode_t val)
-{
-  lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G,
-                             (uint8_t *)&ctrl7_g, 1);
-
-  if (ret == 0)
-  {
-    ctrl7_g.g_hm_mode = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL7_G,
-                                (uint8_t *)&ctrl7_g, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  High-performance operating mode disable for gyroscope.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of g_hm_mode in reg CTRL7_G
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_power_mode_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_g_hm_mode_t *val)
-{
-  lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G,
-                             (uint8_t *)&ctrl7_g, 1);
-
-  switch (ctrl7_g.g_hm_mode)
-  {
-    case LSM6DS3TR_C_GY_HIGH_PERFORMANCE:
-      *val = LSM6DS3TR_C_GY_HIGH_PERFORMANCE;
-      break;
-
-    case LSM6DS3TR_C_GY_NORMAL:
-      *val = LSM6DS3TR_C_GY_NORMAL;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_GY_PW_MODE_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Read all the interrupt/status flag of the device.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    WAKE_UP_SRC, TAP_SRC, D6D_SRC, STATUS_REG,
-  *                FUNC_SRC1, FUNC_SRC2, WRIST_TILT_IA, A_WRIST_TILT_Mask
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_all_sources_get(stmdev_ctx_t *ctx,
-                                    lsm6ds3tr_c_all_sources_t *val)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_SRC,
-                             (uint8_t *) & (val->wake_up_src), 1);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_SRC,
-                               (uint8_t *) & (val->tap_src), 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_D6D_SRC,
-                               (uint8_t *) & (val->d6d_src), 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STATUS_REG,
-                               (uint8_t *) & (val->status_reg), 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FUNC_SRC1,
-                               (uint8_t *) & (val->func_src1), 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FUNC_SRC2,
-                               (uint8_t *) & (val->func_src2), 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WRIST_TILT_IA,
-                               (uint8_t *) & (val->wrist_tilt_ia), 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_MASK,
-                               (uint8_t *) & (val->a_wrist_tilt_mask), 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-  }
-
-  return ret;
-}
-/**
-  * @brief  The STATUS_REG register is read by the primary interface[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Registers STATUS_REG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_status_reg_get(stmdev_ctx_t *ctx,
-                                   lsm6ds3tr_c_status_reg_t *val)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STATUS_REG,
-                             (uint8_t *) val, 1);
-
-  return ret;
-}
-
-/**
-  * @brief  Accelerometer new data available.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of xlda in reg STATUS_REG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_flag_data_ready_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val)
-{
-  lsm6ds3tr_c_status_reg_t status_reg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STATUS_REG,
-                             (uint8_t *)&status_reg, 1);
-  *val = status_reg.xlda;
-
-  return ret;
-}
-
-/**
-  * @brief  Gyroscope new data available.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of gda in reg STATUS_REG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_flag_data_ready_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val)
-{
-  lsm6ds3tr_c_status_reg_t status_reg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STATUS_REG,
-                             (uint8_t *)&status_reg, 1);
-  *val = status_reg.gda;
-
-  return ret;
-}
-
-/**
-  * @brief  Temperature new data available.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tda in reg STATUS_REG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_temp_flag_data_ready_get(stmdev_ctx_t *ctx,
-                                             uint8_t *val)
-{
-  lsm6ds3tr_c_status_reg_t status_reg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STATUS_REG,
-                             (uint8_t *)&status_reg, 1);
-  *val = status_reg.tda;
-
-  return ret;
-}
-
-/**
-  * @brief  Accelerometer axis user offset correction expressed in two’s
-  *         complement, weight depends on USR_OFF_W in CTRL6_C.
-  *         The value must be in the range [-127 127].[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that contains data to write
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_usr_offset_set(stmdev_ctx_t *ctx,
-                                      uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_X_OFS_USR, buff, 3);
-
-  return ret;
-}
-
-/**
-  * @brief  Accelerometer axis user offset correction xpressed in two’s
-  *         complement, weight depends on USR_OFF_W in CTRL6_C.
-  *         The value must be in the range [-127 127].[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_usr_offset_get(stmdev_ctx_t *ctx,
-                                      uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_X_OFS_USR, buff, 3);
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_Timestamp
-  * @brief       This section groups all the functions that manage the
-  *              timestamp generation.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Enable timestamp count. The count is saved in TIMESTAMP0_REG (40h),
-  *         TIMESTAMP1_REG (41h) and TIMESTAMP2_REG (42h).[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of timer_en in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_timestamp_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl10_c.timer_en = val;
-
-    if (val != 0x00U)
-    {
-      ctrl10_c.func_en = val;
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                                  (uint8_t *)&ctrl10_c, 1);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable timestamp count. The count is saved in TIMESTAMP0_REG (40h),
-  *         TIMESTAMP1_REG (41h) and TIMESTAMP2_REG (42h).[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of timer_en in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_timestamp_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-  *val = ctrl10_c.timer_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Timestamp register resolution setting.
-  *         Configuration of this bit affects
-  *         TIMESTAMP0_REG(40h), TIMESTAMP1_REG(41h),
-  *         TIMESTAMP2_REG(42h), STEP_TIMESTAMP_L(49h),
-  *         STEP_TIMESTAMP_H(4Ah) and
-  *         STEP_COUNT_DELTA(15h) registers.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of timer_hr in reg WAKE_UP_DUR
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_timestamp_res_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_timer_hr_t val)
-{
-  lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                             (uint8_t *)&wake_up_dur, 1);
-
-  if (ret == 0)
-  {
-    wake_up_dur.timer_hr = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                                (uint8_t *)&wake_up_dur, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Timestamp register resolution setting.
-  *         Configuration of this bit affects
-  *         TIMESTAMP0_REG(40h), TIMESTAMP1_REG(41h),
-  *         TIMESTAMP2_REG(42h), STEP_TIMESTAMP_L(49h),
-  *         STEP_TIMESTAMP_H(4Ah) and
-  *         STEP_COUNT_DELTA(15h) registers.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of timer_hr in reg WAKE_UP_DUR
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_timestamp_res_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_timer_hr_t *val)
-{
-  lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                             (uint8_t *)&wake_up_dur, 1);
-
-  switch (wake_up_dur.timer_hr)
-  {
-    case LSM6DS3TR_C_LSB_6ms4:
-      *val = LSM6DS3TR_C_LSB_6ms4;
-      break;
-
-    case LSM6DS3TR_C_LSB_25us:
-      *val = LSM6DS3TR_C_LSB_25us;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_TS_RES_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_Dataoutput
-  * @brief       This section groups all the data output functions.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Circular burst-mode (rounding) read from output registers
-  *         through the primary interface.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of rounding in reg CTRL5_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_rounding_mode_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_rounding_t val)
-{
-  lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                             (uint8_t *)&ctrl5_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl5_c.rounding = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                                (uint8_t *)&ctrl5_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Circular burst-mode (rounding) read from output registers
-  *         through the primary interface.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of rounding in reg CTRL5_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_rounding_mode_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_rounding_t *val)
-{
-  lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                             (uint8_t *)&ctrl5_c, 1);
-
-  switch (ctrl5_c.rounding)
-  {
-    case LSM6DS3TR_C_ROUND_DISABLE:
-      *val = LSM6DS3TR_C_ROUND_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_ROUND_XL:
-      *val = LSM6DS3TR_C_ROUND_XL;
-      break;
-
-    case LSM6DS3TR_C_ROUND_GY:
-      *val = LSM6DS3TR_C_ROUND_GY;
-      break;
-
-    case LSM6DS3TR_C_ROUND_GY_XL:
-      *val = LSM6DS3TR_C_ROUND_GY_XL;
-      break;
-
-    case LSM6DS3TR_C_ROUND_SH1_TO_SH6:
-      *val = LSM6DS3TR_C_ROUND_SH1_TO_SH6;
-      break;
-
-    case LSM6DS3TR_C_ROUND_XL_SH1_TO_SH6:
-      *val = LSM6DS3TR_C_ROUND_XL_SH1_TO_SH6;
-      break;
-
-    case LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH12:
-      *val = LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH12;
-      break;
-
-    case LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH6:
-      *val = LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH6;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_ROUND_OUT_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Temperature data output register (r). L and H registers together
-  *         express a 16-bit word in two’s complement.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_temperature_raw_get(stmdev_ctx_t *ctx,
-                                        int16_t *val)
-{
-  uint8_t buff[2];
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_OUT_TEMP_L, buff, 2);
-  *val = (int16_t)buff[1];
-  *val = (*val * 256) + (int16_t)buff[0];
-
-  return ret;
-}
-
-/**
-  * @brief  Angular rate sensor. The value is expressed as a 16-bit word in
-  *         two’s complement.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_angular_rate_raw_get(stmdev_ctx_t *ctx,
-                                         int16_t *val)
-{
-  uint8_t buff[6];
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_OUTX_L_G, buff, 6);
-  val[0] = (int16_t)buff[1];
-  val[0] = (val[0] * 256) + (int16_t)buff[0];
-  val[1] = (int16_t)buff[3];
-  val[1] = (val[1] * 256) + (int16_t)buff[2];
-  val[2] = (int16_t)buff[5];
-  val[2] = (val[2] * 256) + (int16_t)buff[4];
-
-  return ret;
-}
-
-/**
-  * @brief  Linear acceleration output register. The value is expressed
-  *         as a 16-bit word in two’s complement.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_acceleration_raw_get(stmdev_ctx_t *ctx,
-                                         int16_t *val)
-{
-  uint8_t buff[6];
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_OUTX_L_XL, buff, 6);
-  val[0] = (int16_t)buff[1];
-  val[0] = (val[0] * 256) + (int16_t)buff[0];
-  val[1] = (int16_t)buff[3];
-  val[1] = (val[1] * 256) + (int16_t)buff[2];
-  val[2] = (int16_t)buff[5];
-  val[2] = (val[2] * 256) + (int16_t)buff[4];
-
-  return ret;
-}
-
-/**
-  * @brief  External magnetometer raw data.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mag_calibrated_raw_get(stmdev_ctx_t *ctx,
-                                           int16_t *val)
-{
-  uint8_t buff[6];
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_OUT_MAG_RAW_X_L, buff, 6);
-  val[0] = (int16_t)buff[1];
-  val[0] = (val[0] * 256) + (int16_t)buff[0];
-  val[1] = (int16_t)buff[3];
-  val[1] = (val[1] * 256) + (int16_t)buff[2];
-  val[2] = (int16_t)buff[5];
-  val[2] = (val[2] * 256) + (int16_t)buff[4];
-
-  return ret;
-}
-
-/**
-  * @brief  Read data in FIFO.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buffer Data buffer to store FIFO data.
-  * @param  len    Number of data to read from FIFO.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_raw_data_get(stmdev_ctx_t *ctx,
-                                      uint8_t *buffer,
-                                      uint8_t len)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_DATA_OUT_L, buffer,
-                             len);
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_common
-  * @brief       This section groups common useful functions.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Enable access to the embedded functions/sensor hub
-  *         configuration registers[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of func_cfg_en in reg FUNC_CFG_ACCESS
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mem_bank_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_func_cfg_en_t val)
-{
-  lsm6ds3tr_c_func_cfg_access_t func_cfg_access;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FUNC_CFG_ACCESS,
-                             (uint8_t *)&func_cfg_access, 1);
-
-  if (ret == 0)
-  {
-    func_cfg_access.func_cfg_en = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FUNC_CFG_ACCESS,
-                                (uint8_t *)&func_cfg_access, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable access to the embedded functions/sensor hub configuration
-  *         registers[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of func_cfg_en in reg FUNC_CFG_ACCESS
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mem_bank_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_func_cfg_en_t *val)
-{
-  lsm6ds3tr_c_func_cfg_access_t func_cfg_access;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FUNC_CFG_ACCESS,
-                             (uint8_t *)&func_cfg_access, 1);
-
-  switch (func_cfg_access.func_cfg_en)
-  {
-    case LSM6DS3TR_C_USER_BANK:
-      *val = LSM6DS3TR_C_USER_BANK;
-      break;
-
-    case LSM6DS3TR_C_BANK_B:
-      *val = LSM6DS3TR_C_BANK_B;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_BANK_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Data-ready pulsed / letched mode[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of drdy_pulsed in reg DRDY_PULSE_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_data_ready_mode_set(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_drdy_pulsed_g_t val)
-{
-  lsm6ds3tr_c_drdy_pulse_cfg_g_t drdy_pulse_cfg_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G,
-                             (uint8_t *)&drdy_pulse_cfg_g, 1);
-
-  if (ret == 0)
-  {
-    drdy_pulse_cfg_g.drdy_pulsed = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G,
-                                (uint8_t *)&drdy_pulse_cfg_g, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Data-ready pulsed / letched mode[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of drdy_pulsed in reg DRDY_PULSE_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_data_ready_mode_get(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_drdy_pulsed_g_t *val)
-{
-  lsm6ds3tr_c_drdy_pulse_cfg_g_t drdy_pulse_cfg_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G,
-                             (uint8_t *)&drdy_pulse_cfg_g, 1);
-
-  switch (drdy_pulse_cfg_g.drdy_pulsed)
-  {
-    case LSM6DS3TR_C_DRDY_LATCHED:
-      *val = LSM6DS3TR_C_DRDY_LATCHED;
-      break;
-
-    case LSM6DS3TR_C_DRDY_PULSED:
-      *val = LSM6DS3TR_C_DRDY_PULSED;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_DRDY_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  DeviceWhoamI.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_device_id_get(stmdev_ctx_t *ctx, uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WHO_AM_I, buff, 1);
-
-  return ret;
-}
-
-/**
-  * @brief  Software reset. Restore the default values in user registers[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of sw_reset in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_reset_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl3_c.sw_reset = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                                (uint8_t *)&ctrl3_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Software reset. Restore the default values in user registers[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of sw_reset in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_reset_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-  *val = ctrl3_c.sw_reset;
-
-  return ret;
-}
-
-/**
-  * @brief  Big/Little Endian Data selection.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of ble in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_data_format_set(stmdev_ctx_t *ctx,
-                                    lsm6ds3tr_c_ble_t val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl3_c.ble = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                                (uint8_t *)&ctrl3_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Big/Little Endian Data selection.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of ble in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_data_format_get(stmdev_ctx_t *ctx,
-                                    lsm6ds3tr_c_ble_t *val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  switch (ctrl3_c.ble)
-  {
-    case LSM6DS3TR_C_LSB_AT_LOW_ADD:
-      *val = LSM6DS3TR_C_LSB_AT_LOW_ADD;
-      break;
-
-    case LSM6DS3TR_C_MSB_AT_LOW_ADD:
-      *val = LSM6DS3TR_C_MSB_AT_LOW_ADD;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_DATA_FMT_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Register address automatically incremented during a multiple byte
-  *         access with a serial interface.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of if_inc in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_auto_increment_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl3_c.if_inc = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                                (uint8_t *)&ctrl3_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Register address automatically incremented during a multiple byte
-  *         access with a serial interface.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of if_inc in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_auto_increment_get(stmdev_ctx_t *ctx,
-                                       uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-  *val = ctrl3_c.if_inc;
-
-  return ret;
-}
-
-/**
-  * @brief  Reboot memory content. Reload the calibration parameters.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of boot in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_boot_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl3_c.boot = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                                (uint8_t *)&ctrl3_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Reboot memory content. Reload the calibration parameters.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of boot in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_boot_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-  *val = ctrl3_c.boot;
-
-  return ret;
-}
-
-/**
-  * @brief  Linear acceleration sensor self-test enable.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of st_xl in reg CTRL5_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_self_test_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_st_xl_t val)
-{
-  lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                             (uint8_t *)&ctrl5_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl5_c.st_xl = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                                (uint8_t *)&ctrl5_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Linear acceleration sensor self-test enable.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of st_xl in reg CTRL5_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_self_test_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_st_xl_t *val)
-{
-  lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                             (uint8_t *)&ctrl5_c, 1);
-
-  switch (ctrl5_c.st_xl)
-  {
-    case LSM6DS3TR_C_XL_ST_DISABLE:
-      *val = LSM6DS3TR_C_XL_ST_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_XL_ST_POSITIVE:
-      *val = LSM6DS3TR_C_XL_ST_POSITIVE;
-      break;
-
-    case LSM6DS3TR_C_XL_ST_NEGATIVE:
-      *val = LSM6DS3TR_C_XL_ST_NEGATIVE;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_XL_ST_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Angular rate sensor self-test enable.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of st_g in reg CTRL5_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_self_test_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_st_g_t val)
-{
-  lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                             (uint8_t *)&ctrl5_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl5_c.st_g = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                                (uint8_t *)&ctrl5_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Angular rate sensor self-test enable.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of st_g in reg CTRL5_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_self_test_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_st_g_t *val)
-{
-  lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                             (uint8_t *)&ctrl5_c, 1);
-
-  switch (ctrl5_c.st_g)
-  {
-    case LSM6DS3TR_C_GY_ST_DISABLE:
-      *val = LSM6DS3TR_C_GY_ST_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_GY_ST_POSITIVE:
-      *val = LSM6DS3TR_C_GY_ST_POSITIVE;
-      break;
-
-    case LSM6DS3TR_C_GY_ST_NEGATIVE:
-      *val = LSM6DS3TR_C_GY_ST_NEGATIVE;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_GY_ST_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_filters
-  * @brief       This section group all the functions concerning the filters
-  *              configuration that impact both accelerometer and gyro.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Mask DRDY on pin (both XL & Gyro) until filter settling ends
-  *         (XL and Gyro independently masked).[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of drdy_mask in reg CTRL4_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_filter_settling_mask_set(stmdev_ctx_t *ctx,
-                                             uint8_t val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                             (uint8_t *)&ctrl4_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl4_c.drdy_mask = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                                (uint8_t *)&ctrl4_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Mask DRDY on pin (both XL & Gyro) until filter settling ends
-  *         (XL and Gyro independently masked).[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of drdy_mask in reg CTRL4_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_filter_settling_mask_get(stmdev_ctx_t *ctx,
-                                             uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                             (uint8_t *)&ctrl4_c, 1);
-  *val = ctrl4_c.drdy_mask;
-
-  return ret;
-}
-
-/**
-  * @brief  HPF or SLOPE filter selection on wake-up and Activity/Inactivity
-  *         functions.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of slope_fds in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_hp_path_internal_set(stmdev_ctx_t *ctx,
-                                            lsm6ds3tr_c_slope_fds_t val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-
-  if (ret == 0)
-  {
-    tap_cfg.slope_fds = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                                (uint8_t *)&tap_cfg, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  HPF or SLOPE filter selection on wake-up and Activity/Inactivity
-  *         functions.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of slope_fds in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_hp_path_internal_get(stmdev_ctx_t *ctx,
-                                            lsm6ds3tr_c_slope_fds_t *val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-
-  switch (tap_cfg.slope_fds)
-  {
-    case LSM6DS3TR_C_USE_SLOPE:
-      *val = LSM6DS3TR_C_USE_SLOPE;
-      break;
-
-    case LSM6DS3TR_C_USE_HPF:
-      *val = LSM6DS3TR_C_USE_HPF;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_HP_PATH_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_accelerometer_filters
-  * @brief       This section group all the functions concerning the filters
-  *              configuration that impact accelerometer in every mode.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Accelerometer analog chain bandwidth selection (only for
-  *         accelerometer ODR ≥ 1.67 kHz).[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of bw0_xl in reg CTRL1_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_filter_analog_set(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_bw0_xl_t val)
-{
-  lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                             (uint8_t *)&ctrl1_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl1_xl.bw0_xl = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                                (uint8_t *)&ctrl1_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Accelerometer analog chain bandwidth selection (only for
-  *         accelerometer ODR ≥ 1.67 kHz).[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of bw0_xl in reg CTRL1_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_filter_analog_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_bw0_xl_t *val)
-{
-  lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                             (uint8_t *)&ctrl1_xl, 1);
-
-  switch (ctrl1_xl.bw0_xl)
-  {
-    case LSM6DS3TR_C_XL_ANA_BW_1k5Hz:
-      *val = LSM6DS3TR_C_XL_ANA_BW_1k5Hz;
-      break;
-
-    case LSM6DS3TR_C_XL_ANA_BW_400Hz:
-      *val = LSM6DS3TR_C_XL_ANA_BW_400Hz;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_XL_ANA_BW_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_accelerometer_filters
-  * @brief       This section group all the functions concerning the filters
-  *              configuration that impact accelerometer.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Accelerometer digital LPF (LPF1) bandwidth selection LPF2 is
-  *         not used.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of lpf1_bw_sel in reg CTRL1_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_lp1_bandwidth_set(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_lpf1_bw_sel_t val)
-{
-  lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
-  lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                             (uint8_t *)&ctrl1_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl1_xl.lpf1_bw_sel = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                                (uint8_t *)&ctrl1_xl, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                                 (uint8_t *)&ctrl8_xl, 1);
-
-      if (ret == 0)
-      {
-        ctrl8_xl.lpf2_xl_en = 0;
-        ctrl8_xl.hp_slope_xl_en = 0;
-        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                                    (uint8_t *)&ctrl8_xl, 1);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Accelerometer digital LPF (LPF1) bandwidth selection LPF2
-  *         is not used.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of lpf1_bw_sel in reg CTRL1_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_lp1_bandwidth_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_lpf1_bw_sel_t *val)
-{
-  lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
-  lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                             (uint8_t *)&ctrl8_xl, 1);
-
-  if (ret == 0)
-  {
-    if ((ctrl8_xl.lpf2_xl_en != 0x00U) ||
-        (ctrl8_xl.hp_slope_xl_en != 0x00U))
-    {
-      *val = LSM6DS3TR_C_XL_LP1_NA;
-    }
-
-    else
-    {
-      ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL,
-                                 (uint8_t *)&ctrl1_xl, 1);
-
-      switch (ctrl1_xl.lpf1_bw_sel)
-      {
-        case LSM6DS3TR_C_XL_LP1_ODR_DIV_2:
-          *val = LSM6DS3TR_C_XL_LP1_ODR_DIV_2;
-          break;
-
-        case LSM6DS3TR_C_XL_LP1_ODR_DIV_4:
-          *val = LSM6DS3TR_C_XL_LP1_ODR_DIV_4;
-          break;
-
-        default:
-          *val = LSM6DS3TR_C_XL_LP1_NA;
-          break;
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  LPF2 on outputs[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of input_composite in reg CTRL8_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_lp2_bandwidth_set(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_input_composite_t val)
-{
-  lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                             (uint8_t *)&ctrl8_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl8_xl.input_composite = ((uint8_t) val & 0x10U) >> 4;
-    ctrl8_xl.hpcf_xl = (uint8_t) val & 0x03U;
-    ctrl8_xl.lpf2_xl_en = 1;
-    ctrl8_xl.hp_slope_xl_en = 0;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                                (uint8_t *)&ctrl8_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  LPF2 on outputs[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of input_composite in reg CTRL8_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_lp2_bandwidth_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_input_composite_t *val)
-{
-  lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                             (uint8_t *)&ctrl8_xl, 1);
-
-  if (ret == 0)
-  {
-    if ((ctrl8_xl.lpf2_xl_en == 0x00U) ||
-        (ctrl8_xl.hp_slope_xl_en != 0x00U))
-    {
-      *val = LSM6DS3TR_C_XL_LP_NA;
-    }
-
-    else
-    {
-      switch ((ctrl8_xl.input_composite << 4) + ctrl8_xl.hpcf_xl)
-      {
-        case LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_50:
-          *val = LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_50;
-          break;
-
-        case LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_100:
-          *val = LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_100;
-          break;
-
-        case LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_9:
-          *val = LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_9;
-          break;
-
-        case LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_400:
-          *val = LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_400;
-          break;
-
-        case LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_50:
-          *val = LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_50;
-          break;
-
-        case LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_100:
-          *val = LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_100;
-          break;
-
-        case LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_9:
-          *val = LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_9;
-          break;
-
-        case LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_400:
-          *val = LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_400;
-          break;
-
-        default:
-          *val = LSM6DS3TR_C_XL_LP_NA;
-          break;
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable HP filter reference mode.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of hp_ref_mode in reg CTRL8_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_reference_mode_set(stmdev_ctx_t *ctx,
-                                          uint8_t val)
-{
-  lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                             (uint8_t *)&ctrl8_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl8_xl.hp_ref_mode = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                                (uint8_t *)&ctrl8_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable HP filter reference mode.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of hp_ref_mode in reg CTRL8_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_reference_mode_get(stmdev_ctx_t *ctx,
-                                          uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                             (uint8_t *)&ctrl8_xl, 1);
-  *val = ctrl8_xl.hp_ref_mode;
-
-  return ret;
-}
-
-/**
-  * @brief  High pass/Slope on outputs.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of hpcf_xl in reg CTRL8_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_hp_bandwidth_set(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_hpcf_xl_t val)
-{
-  lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                             (uint8_t *)&ctrl8_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl8_xl.input_composite = 0;
-    ctrl8_xl.hpcf_xl = (uint8_t)val & 0x03U;
-    ctrl8_xl.hp_slope_xl_en = 1;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                                (uint8_t *)&ctrl8_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  High pass/Slope on outputs.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of hpcf_xl in reg CTRL8_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_xl_hp_bandwidth_get(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_hpcf_xl_t *val)
-{
-  lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                             (uint8_t *)&ctrl8_xl, 1);
-
-  if (ctrl8_xl.hp_slope_xl_en == 0x00U)
-  {
-    *val = LSM6DS3TR_C_XL_HP_NA;
-  }
-
-  switch (ctrl8_xl.hpcf_xl)
-  {
-    case LSM6DS3TR_C_XL_HP_ODR_DIV_4:
-      *val = LSM6DS3TR_C_XL_HP_ODR_DIV_4;
-      break;
-
-    case LSM6DS3TR_C_XL_HP_ODR_DIV_100:
-      *val = LSM6DS3TR_C_XL_HP_ODR_DIV_100;
-      break;
-
-    case LSM6DS3TR_C_XL_HP_ODR_DIV_9:
-      *val = LSM6DS3TR_C_XL_HP_ODR_DIV_9;
-      break;
-
-    case LSM6DS3TR_C_XL_HP_ODR_DIV_400:
-      *val = LSM6DS3TR_C_XL_HP_ODR_DIV_400;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_XL_HP_NA;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_gyroscope_filters
-  * @brief       This section group all the functions concerning the filters
-  *              configuration that impact gyroscope.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Gyroscope low pass path bandwidth.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    gyroscope filtering chain configuration.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_band_pass_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_lpf1_sel_g_t val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
-  lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G,
-                             (uint8_t *)&ctrl7_g, 1);
-
-  if (ret == 0)
-  {
-    ctrl7_g.hpm_g  = ((uint8_t)val & 0x30U) >> 4;
-    ctrl7_g.hp_en_g = ((uint8_t)val & 0x80U) >> 7;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL7_G,
-                                (uint8_t *)&ctrl7_g, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                                 (uint8_t *)&ctrl6_c, 1);
-
-      if (ret == 0)
-      {
-        ctrl6_c.ftype = (uint8_t)val & 0x03U;
-        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                                    (uint8_t *)&ctrl6_c, 1);
-
-        if (ret == 0)
-        {
-          ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                                     (uint8_t *)&ctrl4_c, 1);
-
-          if (ret == 0)
-          {
-            ctrl4_c.lpf1_sel_g = ((uint8_t)val & 0x08U) >> 3;
-            ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                                        (uint8_t *)&ctrl4_c, 1);
-          }
-        }
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Gyroscope low pass path bandwidth.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    gyroscope filtering chain
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_band_pass_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_lpf1_sel_g_t *val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
-  lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                             (uint8_t *)&ctrl6_c, 1);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                               (uint8_t *)&ctrl4_c, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G,
-                                 (uint8_t *)&ctrl7_g, 1);
-
-      switch ((ctrl7_g.hp_en_g << 7) + (ctrl7_g.hpm_g << 4) +
-              (ctrl4_c.lpf1_sel_g << 3) + ctrl6_c.ftype)
-      {
-        case LSM6DS3TR_C_HP_16mHz_LP2:
-          *val = LSM6DS3TR_C_HP_16mHz_LP2;
-          break;
-
-        case LSM6DS3TR_C_HP_65mHz_LP2:
-          *val = LSM6DS3TR_C_HP_65mHz_LP2;
-          break;
-
-        case LSM6DS3TR_C_HP_260mHz_LP2:
-          *val = LSM6DS3TR_C_HP_260mHz_LP2;
-          break;
-
-        case LSM6DS3TR_C_HP_1Hz04_LP2:
-          *val = LSM6DS3TR_C_HP_1Hz04_LP2;
-          break;
-
-        case LSM6DS3TR_C_HP_DISABLE_LP1_LIGHT:
-          *val = LSM6DS3TR_C_HP_DISABLE_LP1_LIGHT;
-          break;
-
-        case LSM6DS3TR_C_HP_DISABLE_LP1_NORMAL:
-          *val = LSM6DS3TR_C_HP_DISABLE_LP1_NORMAL;
-          break;
-
-        case LSM6DS3TR_C_HP_DISABLE_LP_STRONG:
-          *val = LSM6DS3TR_C_HP_DISABLE_LP_STRONG;
-          break;
-
-        case LSM6DS3TR_C_HP_DISABLE_LP1_AGGRESSIVE:
-          *val = LSM6DS3TR_C_HP_DISABLE_LP1_AGGRESSIVE;
-          break;
-
-        case LSM6DS3TR_C_HP_16mHz_LP1_LIGHT:
-          *val = LSM6DS3TR_C_HP_16mHz_LP1_LIGHT;
-          break;
-
-        case LSM6DS3TR_C_HP_65mHz_LP1_NORMAL:
-          *val = LSM6DS3TR_C_HP_65mHz_LP1_NORMAL;
-          break;
-
-        case LSM6DS3TR_C_HP_260mHz_LP1_STRONG:
-          *val = LSM6DS3TR_C_HP_260mHz_LP1_STRONG;
-          break;
-
-        case LSM6DS3TR_C_HP_1Hz04_LP1_AGGRESSIVE:
-          *val = LSM6DS3TR_C_HP_1Hz04_LP1_AGGRESSIVE;
-          break;
-
-        default:
-          *val = LSM6DS3TR_C_HP_GY_BAND_NA;
-          break;
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_serial_interface
-  * @brief       This section groups all the functions concerning serial
-  *              interface management
-  * @{
-  *
-  */
-
-/**
-  * @brief  SPI Serial Interface Mode selection.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of sim in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_spi_mode_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_sim_t val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl3_c.sim = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                                (uint8_t *)&ctrl3_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  SPI Serial Interface Mode selection.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of sim in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_spi_mode_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_sim_t *val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  switch (ctrl3_c.sim)
-  {
-    case LSM6DS3TR_C_SPI_4_WIRE:
-      *val = LSM6DS3TR_C_SPI_4_WIRE;
-      break;
-
-    case LSM6DS3TR_C_SPI_3_WIRE:
-      *val = LSM6DS3TR_C_SPI_3_WIRE;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_SPI_MODE_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Disable / Enable I2C interface.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of i2c_disable in reg CTRL4_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_i2c_interface_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_i2c_disable_t val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                             (uint8_t *)&ctrl4_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl4_c.i2c_disable = (uint8_t)val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                                (uint8_t *)&ctrl4_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Disable / Enable I2C interface.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of i2c_disable in reg CTRL4_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_i2c_interface_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_i2c_disable_t *val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                             (uint8_t *)&ctrl4_c, 1);
-
-  switch (ctrl4_c.i2c_disable)
-  {
-    case LSM6DS3TR_C_I2C_ENABLE:
-      *val = LSM6DS3TR_C_I2C_ENABLE;
-      break;
-
-    case LSM6DS3TR_C_I2C_DISABLE:
-      *val = LSM6DS3TR_C_I2C_DISABLE;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_I2C_MODE_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_interrupt_pins
-  * @brief       This section groups all the functions that manage
-  *              interrupt pins
-  * @{
-  *
-  */
-
-/**
-  * @brief  Select the signal that need to route on int1 pad[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    configure INT1_CTRL, MD1_CFG, CTRL4_C(den_drdy_int1),
-  *                MASTER_CONFIG(drdy_on_int1)
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pin_int1_route_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_int1_route_t val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  lsm6ds3tr_c_int1_ctrl_t int1_ctrl;
-  lsm6ds3tr_c_md1_cfg_t md1_cfg;
-  lsm6ds3tr_c_md2_cfg_t md2_cfg;
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT1_CTRL,
-                             (uint8_t *)&int1_ctrl, 1);
-
-  if (ret == 0)
-  {
-    int1_ctrl.int1_drdy_xl        = val.int1_drdy_xl;
-    int1_ctrl.int1_drdy_g         = val.int1_drdy_g;
-    int1_ctrl.int1_boot           = val.int1_boot;
-    int1_ctrl.int1_fth            = val.int1_fth;
-    int1_ctrl.int1_fifo_ovr       = val.int1_fifo_ovr;
-    int1_ctrl.int1_full_flag      = val.int1_full_flag;
-    int1_ctrl.int1_sign_mot       = val.int1_sign_mot;
-    int1_ctrl.int1_step_detector  = val.int1_step_detector;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_INT1_CTRL,
-                                (uint8_t *)&int1_ctrl, 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD1_CFG,
-                               (uint8_t *)&md1_cfg, 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD2_CFG,
-                               (uint8_t *)&md2_cfg, 1);
-  }
-
-  if (ret == 0)
-  {
-    md1_cfg.int1_timer           = val.int1_timer;
-    md1_cfg.int1_tilt            = val.int1_tilt;
-    md1_cfg.int1_6d              = val.int1_6d;
-    md1_cfg.int1_double_tap      = val.int1_double_tap;
-    md1_cfg.int1_ff              = val.int1_ff;
-    md1_cfg.int1_wu              = val.int1_wu;
-    md1_cfg.int1_single_tap      = val.int1_single_tap;
-    md1_cfg.int1_inact_state     = val.int1_inact_state;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MD1_CFG,
-                                (uint8_t *)&md1_cfg, 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                               (uint8_t *)&ctrl4_c, 1);
-  }
-
-  if (ret == 0)
-  {
-    ctrl4_c.den_drdy_int1 = val.den_drdy_int1;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                                (uint8_t *)&ctrl4_c, 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                               (uint8_t *)&master_config, 1);
-  }
-
-  if (ret == 0)
-  {
-    master_config.drdy_on_int1   = val.den_drdy_int1;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                                (uint8_t *)&master_config, 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                               (uint8_t *)&tap_cfg, 1);
-
-    if ((val.int1_6d != 0x00U) ||
-        (val.int1_ff != 0x00U) ||
-        (val.int1_wu != 0x00U) ||
-        (val.int1_single_tap != 0x00U) ||
-        (val.int1_double_tap != 0x00U) ||
-        (val.int1_inact_state != 0x00U) ||
-        (md2_cfg.int2_6d != 0x00U) ||
-        (md2_cfg.int2_ff != 0x00U) ||
-        (md2_cfg.int2_wu != 0x00U) ||
-        (md2_cfg.int2_single_tap != 0x00U) ||
-        (md2_cfg.int2_double_tap != 0x00U) ||
-        (md2_cfg.int2_inact_state != 0x00U))
-    {
-      tap_cfg.interrupts_enable = PROPERTY_ENABLE;
-    }
-
-    else
-    {
-      tap_cfg.interrupts_enable = PROPERTY_DISABLE;
-    }
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                                (uint8_t *)&tap_cfg, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Select the signal that need to route on int1 pad[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    read INT1_CTRL, MD1_CFG, CTRL4_C(den_drdy_int1),
-  *                MASTER_CONFIG(drdy_on_int1)
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pin_int1_route_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_int1_route_t *val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  lsm6ds3tr_c_int1_ctrl_t int1_ctrl;
-  lsm6ds3tr_c_md1_cfg_t md1_cfg;
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT1_CTRL,
-                             (uint8_t *)&int1_ctrl, 1);
-
-  if (ret == 0)
-  {
-    val->int1_drdy_xl       = int1_ctrl.int1_drdy_xl;
-    val->int1_drdy_g        = int1_ctrl.int1_drdy_g;
-    val->int1_boot          = int1_ctrl.int1_boot;
-    val->int1_fth           = int1_ctrl.int1_fth;
-    val->int1_fifo_ovr      = int1_ctrl.int1_fifo_ovr;
-    val->int1_full_flag     = int1_ctrl.int1_full_flag;
-    val->int1_sign_mot      = int1_ctrl.int1_sign_mot;
-    val->int1_step_detector = int1_ctrl.int1_step_detector ;
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD1_CFG,
-                               (uint8_t *)&md1_cfg, 1);
-
-    if (ret == 0)
-    {
-      val->int1_timer       = md1_cfg.int1_timer;
-      val->int1_tilt        = md1_cfg.int1_tilt;
-      val->int1_6d          = md1_cfg.int1_6d;
-      val->int1_double_tap  = md1_cfg.int1_double_tap;
-      val->int1_ff          = md1_cfg.int1_ff;
-      val->int1_wu          = md1_cfg.int1_wu;
-      val->int1_single_tap  = md1_cfg.int1_single_tap;
-      val->int1_inact_state = md1_cfg.int1_inact_state;
-      ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                                 (uint8_t *)&ctrl4_c, 1);
-
-      if (ret == 0)
-      {
-        val->den_drdy_int1 = ctrl4_c.den_drdy_int1;
-        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                                   (uint8_t *)&master_config, 1);
-        val->den_drdy_int1 = master_config.drdy_on_int1;
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Select the signal that need to route on int2 pad[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    INT2_CTRL, DRDY_PULSE_CFG(int2_wrist_tilt), MD2_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pin_int2_route_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_int2_route_t val)
-{
-  lsm6ds3tr_c_int2_ctrl_t int2_ctrl;
-  lsm6ds3tr_c_md1_cfg_t md1_cfg;
-  lsm6ds3tr_c_md2_cfg_t md2_cfg;
-  lsm6ds3tr_c_drdy_pulse_cfg_g_t drdy_pulse_cfg_g;
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT2_CTRL,
-                             (uint8_t *)&int2_ctrl, 1);
-
-  if (ret == 0)
-  {
-    int2_ctrl.int2_drdy_xl        = val.int2_drdy_xl;
-    int2_ctrl.int2_drdy_g         = val.int2_drdy_g;
-    int2_ctrl.int2_drdy_temp      = val.int2_drdy_temp;
-    int2_ctrl.int2_fth            = val.int2_fth;
-    int2_ctrl.int2_fifo_ovr       = val.int2_fifo_ovr;
-    int2_ctrl.int2_full_flag      = val.int2_full_flag;
-    int2_ctrl.int2_step_count_ov  = val.int2_step_count_ov;
-    int2_ctrl.int2_step_delta     = val.int2_step_delta;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_INT2_CTRL,
-                                (uint8_t *)&int2_ctrl, 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD1_CFG,
-                               (uint8_t *)&md1_cfg, 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD2_CFG,
-                               (uint8_t *)&md2_cfg, 1);
-  }
-
-  if (ret == 0)
-  {
-    md2_cfg.int2_iron              = val.int2_iron;
-    md2_cfg.int2_tilt              = val.int2_tilt;
-    md2_cfg.int2_6d                = val.int2_6d;
-    md2_cfg.int2_double_tap        = val.int2_double_tap;
-    md2_cfg.int2_ff                = val.int2_ff;
-    md2_cfg.int2_wu                = val.int2_wu;
-    md2_cfg.int2_single_tap        = val.int2_single_tap;
-    md2_cfg.int2_inact_state       = val.int2_inact_state;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MD2_CFG,
-                                (uint8_t *)&md2_cfg, 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G,
-                               (uint8_t *)&drdy_pulse_cfg_g, 1);
-  }
-
-  if (ret == 0)
-  {
-    drdy_pulse_cfg_g.int2_wrist_tilt = val.int2_wrist_tilt;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G,
-                                (uint8_t *)&drdy_pulse_cfg_g, 1);
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                               (uint8_t *)&tap_cfg, 1);
-
-    if ((md1_cfg.int1_6d != 0x00U) ||
-        (md1_cfg.int1_ff != 0x00U) ||
-        (md1_cfg.int1_wu != 0x00U) ||
-        (md1_cfg.int1_single_tap != 0x00U) ||
-        (md1_cfg.int1_double_tap != 0x00U) ||
-        (md1_cfg.int1_inact_state != 0x00U) ||
-        (val.int2_6d != 0x00U) ||
-        (val.int2_ff != 0x00U) ||
-        (val.int2_wu != 0x00U) ||
-        (val.int2_single_tap != 0x00U) ||
-        (val.int2_double_tap != 0x00U) ||
-        (val.int2_inact_state != 0x00U))
-    {
-      tap_cfg.interrupts_enable = PROPERTY_ENABLE;
-    }
-
-    else
-    {
-      tap_cfg.interrupts_enable = PROPERTY_DISABLE;
-    }
-  }
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                                (uint8_t *)&tap_cfg, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Select the signal that need to route on int2 pad[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    INT2_CTRL, DRDY_PULSE_CFG(int2_wrist_tilt), MD2_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pin_int2_route_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_int2_route_t *val)
-{
-  lsm6ds3tr_c_int2_ctrl_t int2_ctrl;
-  lsm6ds3tr_c_md2_cfg_t md2_cfg;
-  lsm6ds3tr_c_drdy_pulse_cfg_g_t drdy_pulse_cfg_g;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT2_CTRL,
-                             (uint8_t *)&int2_ctrl, 1);
-
-  if (ret == 0)
-  {
-    val->int2_drdy_xl         = int2_ctrl.int2_drdy_xl;
-    val->int2_drdy_g          = int2_ctrl.int2_drdy_g;
-    val->int2_drdy_temp       = int2_ctrl.int2_drdy_temp;
-    val->int2_fth             = int2_ctrl.int2_fth;
-    val->int2_fifo_ovr        = int2_ctrl.int2_fifo_ovr;
-    val->int2_full_flag       = int2_ctrl.int2_full_flag;
-    val->int2_step_count_ov   = int2_ctrl.int2_step_count_ov;
-    val->int2_step_delta      = int2_ctrl.int2_step_delta;
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD2_CFG,
-                               (uint8_t *)&md2_cfg, 1);
-
-    if (ret == 0)
-    {
-      val->int2_iron           = md2_cfg.int2_iron;
-      val->int2_tilt           = md2_cfg.int2_tilt;
-      val->int2_6d             = md2_cfg.int2_6d;
-      val->int2_double_tap     = md2_cfg.int2_double_tap;
-      val->int2_ff             = md2_cfg.int2_ff;
-      val->int2_wu             = md2_cfg.int2_wu;
-      val->int2_single_tap     = md2_cfg.int2_single_tap;
-      val->int2_inact_state    = md2_cfg.int2_inact_state;
-      ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G,
-                                 (uint8_t *)&drdy_pulse_cfg_g, 1);
-      val->int2_wrist_tilt = drdy_pulse_cfg_g.int2_wrist_tilt;
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Push-pull/open drain selection on interrupt pads.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of pp_od in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pin_mode_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_pp_od_t val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl3_c.pp_od = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                                (uint8_t *)&ctrl3_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Push-pull/open drain selection on interrupt pads.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of pp_od in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pin_mode_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_pp_od_t *val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  switch (ctrl3_c.pp_od)
-  {
-    case LSM6DS3TR_C_PUSH_PULL:
-      *val = LSM6DS3TR_C_PUSH_PULL;
-      break;
-
-    case LSM6DS3TR_C_OPEN_DRAIN:
-      *val = LSM6DS3TR_C_OPEN_DRAIN;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_PIN_MODE_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Interrupt active-high/low.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of h_lactive in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pin_polarity_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_h_lactive_t val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl3_c.h_lactive = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                                (uint8_t *)&ctrl3_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Interrupt active-high/low.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of h_lactive in reg CTRL3_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pin_polarity_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_h_lactive_t *val)
-{
-  lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C,
-                             (uint8_t *)&ctrl3_c, 1);
-
-  switch (ctrl3_c.h_lactive)
-  {
-    case LSM6DS3TR_C_ACTIVE_HIGH:
-      *val = LSM6DS3TR_C_ACTIVE_HIGH;
-      break;
-
-    case LSM6DS3TR_C_ACTIVE_LOW:
-      *val = LSM6DS3TR_C_ACTIVE_LOW;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_POLARITY_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  All interrupt signals become available on INT1 pin.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of int2_on_int1 in reg CTRL4_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_all_on_int1_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                             (uint8_t *)&ctrl4_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl4_c.int2_on_int1 = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                                (uint8_t *)&ctrl4_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  All interrupt signals become available on INT1 pin.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of int2_on_int1 in reg CTRL4_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_all_on_int1_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                             (uint8_t *)&ctrl4_c, 1);
-  *val = ctrl4_c.int2_on_int1;
-
-  return ret;
-}
-
-/**
-  * @brief  Latched/pulsed interrupt.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of lir in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_int_notification_set(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_lir_t val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-
-  if (ret == 0)
-  {
-    tap_cfg.lir = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                                (uint8_t *)&tap_cfg, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Latched/pulsed interrupt.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of lir in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_int_notification_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_lir_t *val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-
-  switch (tap_cfg.lir)
-  {
-    case LSM6DS3TR_C_INT_PULSED:
-      *val = LSM6DS3TR_C_INT_PULSED;
-      break;
-
-    case LSM6DS3TR_C_INT_LATCHED:
-      *val = LSM6DS3TR_C_INT_LATCHED;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_INT_MODE;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_Wake_Up_event
-  * @brief       This section groups all the functions that manage the
-  *              Wake Up event generation.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Threshold for wakeup.1 LSB = FS_XL / 64.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of wk_ths in reg WAKE_UP_THS
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_wkup_threshold_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_wake_up_ths_t wake_up_ths;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS,
-                             (uint8_t *)&wake_up_ths, 1);
-
-  if (ret == 0)
-  {
-    wake_up_ths.wk_ths = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS,
-                                (uint8_t *)&wake_up_ths, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Threshold for wakeup.1 LSB = FS_XL / 64.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of wk_ths in reg WAKE_UP_THS
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_wkup_threshold_get(stmdev_ctx_t *ctx,
-                                       uint8_t *val)
-{
-  lsm6ds3tr_c_wake_up_ths_t wake_up_ths;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS,
-                             (uint8_t *)&wake_up_ths, 1);
-  *val = wake_up_ths.wk_ths;
-
-  return ret;
-}
-
-/**
-  * @brief  Wake up duration event.1LSb = 1 / ODR[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of wake_dur in reg WAKE_UP_DUR
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_wkup_dur_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                             (uint8_t *)&wake_up_dur, 1);
-
-  if (ret == 0)
-  {
-    wake_up_dur.wake_dur = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                                (uint8_t *)&wake_up_dur, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Wake up duration event.1LSb = 1 / ODR[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of wake_dur in reg WAKE_UP_DUR
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_wkup_dur_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                             (uint8_t *)&wake_up_dur, 1);
-  *val = wake_up_dur.wake_dur;
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_Activity/Inactivity_detection
-  * @brief       This section groups all the functions concerning
-  *              activity/inactivity detection.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Enables gyroscope Sleep mode.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of sleep in reg CTRL4_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_sleep_mode_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                             (uint8_t *)&ctrl4_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl4_c.sleep = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                                (uint8_t *)&ctrl4_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enables gyroscope Sleep mode.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of sleep in reg CTRL4_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_gy_sleep_mode_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                             (uint8_t *)&ctrl4_c, 1);
-  *val = ctrl4_c.sleep;
-
-  return ret;
-}
-
-/**
-  * @brief  Enable inactivity function.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of inact_en in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_act_mode_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_inact_en_t val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-
-  if (ret == 0)
-  {
-    tap_cfg.inact_en = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                                (uint8_t *)&tap_cfg, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable inactivity function.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of inact_en in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_act_mode_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_inact_en_t *val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-
-  switch (tap_cfg.inact_en)
-  {
-    case LSM6DS3TR_C_PROPERTY_DISABLE:
-      *val = LSM6DS3TR_C_PROPERTY_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_XL_12Hz5_GY_NOT_AFFECTED:
-      *val = LSM6DS3TR_C_XL_12Hz5_GY_NOT_AFFECTED;
-      break;
-
-    case LSM6DS3TR_C_XL_12Hz5_GY_SLEEP:
-      *val = LSM6DS3TR_C_XL_12Hz5_GY_SLEEP;
-      break;
-
-    case LSM6DS3TR_C_XL_12Hz5_GY_PD:
-      *val = LSM6DS3TR_C_XL_12Hz5_GY_PD;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_ACT_MODE_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Duration to go in sleep mode.1 LSb = 512 / ODR[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of sleep_dur in reg WAKE_UP_DUR
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_act_sleep_dur_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                             (uint8_t *)&wake_up_dur, 1);
-
-  if (ret == 0)
-  {
-    wake_up_dur.sleep_dur = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                                (uint8_t *)&wake_up_dur, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Duration to go in sleep mode. 1 LSb = 512 / ODR[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of sleep_dur in reg WAKE_UP_DUR
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_act_sleep_dur_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                             (uint8_t *)&wake_up_dur, 1);
-  *val = wake_up_dur.sleep_dur;
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_tap_generator
-  * @brief       This section groups all the functions that manage the
-  *              tap and double tap event generation.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Read the tap / double tap source register.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Structure of registers from TAP_SRC
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_src_get(stmdev_ctx_t *ctx,
-                                lsm6ds3tr_c_tap_src_t *val)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_SRC, (uint8_t *) val, 1);
-
-  return ret;
-}
-
-/**
-  * @brief  Enable Z direction in tap recognition.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tap_z_en in reg TAP_CFG
-  *
-  */
-int32_t lsm6ds3tr_c_tap_detection_on_z_set(stmdev_ctx_t *ctx,
-                                           uint8_t val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-
-  if (ret == 0)
-  {
-    tap_cfg.tap_z_en = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                                (uint8_t *)&tap_cfg, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable Z direction in tap recognition.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tap_z_en in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_detection_on_z_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-  *val = tap_cfg.tap_z_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Enable Y direction in tap recognition.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tap_y_en in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_detection_on_y_set(stmdev_ctx_t *ctx,
-                                           uint8_t val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-
-  if (ret == 0)
-  {
-    tap_cfg.tap_y_en = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                                (uint8_t *)&tap_cfg, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable Y direction in tap recognition.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tap_y_en in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_detection_on_y_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-  *val = tap_cfg.tap_y_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Enable X direction in tap recognition.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tap_x_en in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_detection_on_x_set(stmdev_ctx_t *ctx,
-                                           uint8_t val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-
-  if (ret == 0)
-  {
-    tap_cfg.tap_x_en = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                                (uint8_t *)&tap_cfg, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable X direction in tap recognition.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tap_x_en in reg TAP_CFG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_detection_on_x_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val)
-{
-  lsm6ds3tr_c_tap_cfg_t tap_cfg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG,
-                             (uint8_t *)&tap_cfg, 1);
-  *val = tap_cfg.tap_x_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Threshold for tap recognition.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tap_ths in reg TAP_THS_6D
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_threshold_x_set(stmdev_ctx_t *ctx,
-                                        uint8_t val)
-{
-  lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D,
-                             (uint8_t *)&tap_ths_6d, 1);
-
-  if (ret == 0)
-  {
-    tap_ths_6d.tap_ths = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_THS_6D,
-                                (uint8_t *)&tap_ths_6d, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Threshold for tap recognition.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tap_ths in reg TAP_THS_6D
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_threshold_x_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val)
-{
-  lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D,
-                             (uint8_t *)&tap_ths_6d, 1);
-  *val = tap_ths_6d.tap_ths;
-
-  return ret;
-}
-
-/**
-  * @brief  Maximum duration is the maximum time of an overthreshold signal
-  *         detection to be recognized as a tap event.
-  *         The default value of these bits is 00b which corresponds to
-  *         4*ODR_XL time.
-  *         If the SHOCK[1:0] bits are set to a different
-  *         value, 1LSB corresponds to 8*ODR_XL time.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of shock in reg INT_DUR2
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_shock_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_int_dur2_t int_dur2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2,
-                             (uint8_t *)&int_dur2, 1);
-
-  if (ret == 0)
-  {
-    int_dur2.shock = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_INT_DUR2,
-                                (uint8_t *)&int_dur2, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Maximum duration is the maximum time of an overthreshold signal
-  *         detection to be recognized as a tap event.
-  *         The default value of these bits is 00b which corresponds to
-  *         4*ODR_XL time.
-  *         If the SHOCK[1:0] bits are set to a different value, 1LSB
-  *         corresponds to 8*ODR_XL time.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of shock in reg INT_DUR2
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_shock_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_int_dur2_t int_dur2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2,
-                             (uint8_t *)&int_dur2, 1);
-  *val = int_dur2.shock;
-
-  return ret;
-}
-
-/**
-  * @brief  Quiet time is the time after the first detected tap in which there
-  *         must not be any overthreshold event.
-  *         The default value of these bits is 00b which corresponds to
-  *         2*ODR_XL time.
-  *         If the QUIET[1:0] bits are set to a different value, 1LSB
-  *         corresponds to 4*ODR_XL time.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of quiet in reg INT_DUR2
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_quiet_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_int_dur2_t int_dur2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2,
-                             (uint8_t *)&int_dur2, 1);
-
-  if (ret == 0)
-  {
-    int_dur2.quiet = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_INT_DUR2,
-                                (uint8_t *)&int_dur2, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Quiet time is the time after the first detected tap in which there
-  *         must not be any overthreshold event.
-  *         The default value of these bits is 00b which corresponds to
-  *         2*ODR_XL time.
-  *         If the QUIET[1:0] bits are set to a different value, 1LSB
-  *         corresponds to 4*ODR_XL time.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of quiet in reg INT_DUR2
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_quiet_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_int_dur2_t int_dur2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2,
-                             (uint8_t *)&int_dur2, 1);
-  *val = int_dur2.quiet;
-
-  return ret;
-}
-
-/**
-  * @brief  When double tap recognition is enabled, this register expresses the
-  *         maximum time between two consecutive detected taps to determine a
-  *         double tap event.
-  *         The default value of these bits is 0000b which corresponds to
-  *         16*ODR_XL time.
-  *         If the DUR[3:0] bits are set to a different value,1LSB corresponds
-  *         to 32*ODR_XL time.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of dur in reg INT_DUR2
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_dur_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_int_dur2_t int_dur2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2,
-                             (uint8_t *)&int_dur2, 1);
-
-  if (ret == 0)
-  {
-    int_dur2.dur = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_INT_DUR2,
-                                (uint8_t *)&int_dur2, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  When double tap recognition is enabled, this register expresses the
-  *         maximum time between two consecutive detected taps to determine a
-  *         double tap event.
-  *         The default value of these bits is 0000b which corresponds to
-  *         16*ODR_XL time.
-  *         If the DUR[3:0] bits are set to a different value,1LSB corresponds
-  *         to 32*ODR_XL time.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of dur in reg INT_DUR2
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_dur_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_int_dur2_t int_dur2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2,
-                             (uint8_t *)&int_dur2, 1);
-  *val = int_dur2.dur;
-
-  return ret;
-}
-
-/**
-  * @brief  Single/double-tap event enable/disable.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of
-  *                                      single_double_tap in reg WAKE_UP_THS
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_mode_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_single_double_tap_t val)
-{
-  lsm6ds3tr_c_wake_up_ths_t wake_up_ths;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS,
-                             (uint8_t *)&wake_up_ths, 1);
-
-  if (ret == 0)
-  {
-    wake_up_ths.single_double_tap = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS,
-                                (uint8_t *)&wake_up_ths, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Single/double-tap event enable/disable.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of single_double_tap
-  *                                      in reg WAKE_UP_THS
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tap_mode_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_single_double_tap_t *val)
-{
-  lsm6ds3tr_c_wake_up_ths_t wake_up_ths;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS,
-                             (uint8_t *)&wake_up_ths, 1);
-
-  switch (wake_up_ths.single_double_tap)
-  {
-    case LSM6DS3TR_C_ONLY_SINGLE:
-      *val = LSM6DS3TR_C_ONLY_SINGLE;
-      break;
-
-    case LSM6DS3TR_C_BOTH_SINGLE_DOUBLE:
-      *val = LSM6DS3TR_C_BOTH_SINGLE_DOUBLE;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_TAP_MODE_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_ Six_position_detection(6D/4D)
-  * @brief       This section groups all the functions concerning six
-  *              position detection (6D).
-  * @{
-  *
-  */
-
-/**
-  * @brief  LPF2 feed 6D function selection.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of low_pass_on_6d in
-  *                                   reg CTRL8_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_6d_feed_data_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_low_pass_on_6d_t val)
-{
-  lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                             (uint8_t *)&ctrl8_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl8_xl.low_pass_on_6d = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                                (uint8_t *)&ctrl8_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  LPF2 feed 6D function selection.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of low_pass_on_6d in reg CTRL8_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_6d_feed_data_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_low_pass_on_6d_t *val)
-{
-  lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL,
-                             (uint8_t *)&ctrl8_xl, 1);
-
-  switch (ctrl8_xl.low_pass_on_6d)
-  {
-    case LSM6DS3TR_C_ODR_DIV_2_FEED:
-      *val = LSM6DS3TR_C_ODR_DIV_2_FEED;
-      break;
-
-    case LSM6DS3TR_C_LPF2_FEED:
-      *val = LSM6DS3TR_C_LPF2_FEED;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_6D_FEED_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Threshold for 4D/6D function.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of sixd_ths in reg TAP_THS_6D
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_6d_threshold_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sixd_ths_t val)
-{
-  lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D,
-                             (uint8_t *)&tap_ths_6d, 1);
-
-  if (ret == 0)
-  {
-    tap_ths_6d.sixd_ths = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_THS_6D,
-                                (uint8_t *)&tap_ths_6d, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Threshold for 4D/6D function.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of sixd_ths in reg TAP_THS_6D
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_6d_threshold_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sixd_ths_t *val)
-{
-  lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D,
-                             (uint8_t *)&tap_ths_6d, 1);
-
-  switch (tap_ths_6d.sixd_ths)
-  {
-    case LSM6DS3TR_C_DEG_80:
-      *val = LSM6DS3TR_C_DEG_80;
-      break;
-
-    case LSM6DS3TR_C_DEG_70:
-      *val = LSM6DS3TR_C_DEG_70;
-      break;
-
-    case LSM6DS3TR_C_DEG_60:
-      *val = LSM6DS3TR_C_DEG_60;
-      break;
-
-    case LSM6DS3TR_C_DEG_50:
-      *val = LSM6DS3TR_C_DEG_50;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_6D_TH_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  4D orientation detection enable.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of d4d_en in reg TAP_THS_6D
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_4d_mode_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D,
-                             (uint8_t *)&tap_ths_6d, 1);
-
-  if (ret == 0)
-  {
-    tap_ths_6d.d4d_en = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_THS_6D,
-                                (uint8_t *)&tap_ths_6d, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  4D orientation detection enable.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of d4d_en in reg TAP_THS_6D
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_4d_mode_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D,
-                             (uint8_t *)&tap_ths_6d, 1);
-  *val = tap_ths_6d.d4d_en;
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_free_fall
-  * @brief       This section group all the functions concerning the free
-  *              fall detection.
-  * @{
-  *
-  */
-
-/**
-  * @brief Free-fall duration event. 1LSb = 1 / ODR[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of ff_dur in reg WAKE_UP_DUR
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_ff_dur_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
-  lsm6ds3tr_c_free_fall_t free_fall;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FREE_FALL,
-                             (uint8_t *)&free_fall, 1);
-
-  if (ret == 0)
-  {
-    free_fall.ff_dur = (val & 0x1FU);
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FREE_FALL,
-                                (uint8_t *)&free_fall, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                                 (uint8_t *)&wake_up_dur, 1);
-
-      if (ret == 0)
-      {
-        wake_up_dur.ff_dur = (val & 0x20U) >> 5;
-        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                                    (uint8_t *)&wake_up_dur, 1);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Free-fall duration event. 1LSb = 1 / ODR[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of ff_dur in reg WAKE_UP_DUR
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_ff_dur_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
-  lsm6ds3tr_c_free_fall_t free_fall;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR,
-                             (uint8_t *)&wake_up_dur, 1);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FREE_FALL,
-                               (uint8_t *)&free_fall, 1);
-  }
-
-  *val = (wake_up_dur.ff_dur << 5) + free_fall.ff_dur;
-
-  return ret;
-}
-
-/**
-  * @brief  Free fall threshold setting.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of ff_ths in reg FREE_FALL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_ff_threshold_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_ff_ths_t val)
-{
-  lsm6ds3tr_c_free_fall_t free_fall;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FREE_FALL,
-                             (uint8_t *)&free_fall, 1);
-
-  if (ret == 0)
-  {
-    free_fall.ff_ths = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FREE_FALL,
-                                (uint8_t *)&free_fall, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Free fall threshold setting.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of ff_ths in reg FREE_FALL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_ff_threshold_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_ff_ths_t *val)
-{
-  lsm6ds3tr_c_free_fall_t free_fall;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FREE_FALL,
-                             (uint8_t *)&free_fall, 1);
-
-  switch (free_fall.ff_ths)
-  {
-    case LSM6DS3TR_C_FF_TSH_156mg:
-      *val = LSM6DS3TR_C_FF_TSH_156mg;
-      break;
-
-    case LSM6DS3TR_C_FF_TSH_219mg:
-      *val = LSM6DS3TR_C_FF_TSH_219mg;
-      break;
-
-    case LSM6DS3TR_C_FF_TSH_250mg:
-      *val = LSM6DS3TR_C_FF_TSH_250mg;
-      break;
-
-    case LSM6DS3TR_C_FF_TSH_312mg:
-      *val = LSM6DS3TR_C_FF_TSH_312mg;
-      break;
-
-    case LSM6DS3TR_C_FF_TSH_344mg:
-      *val = LSM6DS3TR_C_FF_TSH_344mg;
-      break;
-
-    case LSM6DS3TR_C_FF_TSH_406mg:
-      *val = LSM6DS3TR_C_FF_TSH_406mg;
-      break;
-
-    case LSM6DS3TR_C_FF_TSH_469mg:
-      *val = LSM6DS3TR_C_FF_TSH_469mg;
-      break;
-
-    case LSM6DS3TR_C_FF_TSH_500mg:
-      *val = LSM6DS3TR_C_FF_TSH_500mg;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_FF_TSH_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_fifo
-  * @brief       This section group all the functions concerning the
-  *              fifo usage
-  * @{
-  *
-  */
-
-/**
-  * @brief  FIFO watermark level selection.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of fth in reg FIFO_CTRL1
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_watermark_set(stmdev_ctx_t *ctx,
-                                       uint16_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl1_t fifo_ctrl1;
-  lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                             (uint8_t *)&fifo_ctrl2, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl1.fth = (uint8_t)(0x00FFU & val);
-    fifo_ctrl2.fth = (uint8_t)((0x0700U & val) >> 8);
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL1,
-                                (uint8_t *)&fifo_ctrl1, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                                  (uint8_t *)&fifo_ctrl2, 1);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  FIFO watermark level selection.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of fth in reg FIFO_CTRL1
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_watermark_get(stmdev_ctx_t *ctx,
-                                       uint16_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl1_t fifo_ctrl1;
-  lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL1,
-                             (uint8_t *)&fifo_ctrl1, 1);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                               (uint8_t *)&fifo_ctrl2, 1);
-  }
-
-  *val = ((uint16_t)fifo_ctrl2.fth << 8) + (uint16_t)fifo_ctrl1.fth;
-
-  return ret;
-}
-
-/**
-  * @brief  FIFO data level.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    get the values of diff_fifo in reg  FIFO_STATUS1 and
-  *                FIFO_STATUS2(diff_fifo), it is recommended to set the
-  *                BDU bit.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_data_level_get(stmdev_ctx_t *ctx,
-                                        uint16_t *val)
-{
-  lsm6ds3tr_c_fifo_status1_t fifo_status1;
-  lsm6ds3tr_c_fifo_status2_t fifo_status2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_STATUS1,
-                             (uint8_t *)&fifo_status1, 1);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_STATUS2,
-                               (uint8_t *)&fifo_status2, 1);
-    *val = ((uint16_t) fifo_status2.diff_fifo << 8) +
-           (uint16_t) fifo_status1.diff_fifo;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  FIFO watermark.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    get the values of watermark in reg  FIFO_STATUS2 and
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_wtm_flag_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_fifo_status2_t fifo_status2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_STATUS2,
-                             (uint8_t *)&fifo_status2, 1);
-  *val = fifo_status2.waterm;
-
-  return ret;
-}
-
-/**
-  * @brief  FIFO pattern.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    get the values of fifo_pattern in reg  FIFO_STATUS3 and
-  *                FIFO_STATUS4, it is recommended to set the BDU bit
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_pattern_get(stmdev_ctx_t *ctx, uint16_t *val)
-{
-  lsm6ds3tr_c_fifo_status3_t fifo_status3;
-  lsm6ds3tr_c_fifo_status4_t fifo_status4;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_STATUS3,
-                             (uint8_t *)&fifo_status3, 1);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_STATUS4,
-                               (uint8_t *)&fifo_status4, 1);
-    *val = ((uint16_t)fifo_status4.fifo_pattern << 8) +
-           fifo_status3.fifo_pattern;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Batching of temperature data[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of fifo_temp_en in reg FIFO_CTRL2
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_temp_batch_set(stmdev_ctx_t *ctx,
-                                        uint8_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                             (uint8_t *)&fifo_ctrl2, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl2.fifo_temp_en = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                                (uint8_t *)&fifo_ctrl2, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Batching of temperature data[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of fifo_temp_en in reg FIFO_CTRL2
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_temp_batch_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                             (uint8_t *)&fifo_ctrl2, 1);
-  *val = fifo_ctrl2.fifo_temp_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Trigger signal for FIFO write operation.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    act on FIFO_CTRL2(timer_pedo_fifo_drdy)
-  *                and MASTER_CONFIG(data_valid_sel_fifo)
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_write_trigger_set(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_trigger_fifo_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                             (uint8_t *)&fifo_ctrl2, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl2.timer_pedo_fifo_drdy = (uint8_t)val & 0x01U;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                                (uint8_t *)&fifo_ctrl2, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                                 (uint8_t *)&master_config, 1);
-
-      if (ret == 0)
-      {
-        master_config.data_valid_sel_fifo = (((uint8_t)val & 0x02U) >> 1);
-        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                                    (uint8_t *)&master_config, 1);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Trigger signal for FIFO write operation.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    act on FIFO_CTRL2(timer_pedo_fifo_drdy)
-  *                and MASTER_CONFIG(data_valid_sel_fifo)
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_write_trigger_get(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_trigger_fifo_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                             (uint8_t *)&fifo_ctrl2, 1);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                               (uint8_t *)&master_config, 1);
-
-    switch ((fifo_ctrl2.timer_pedo_fifo_drdy << 1) +
-            fifo_ctrl2. timer_pedo_fifo_drdy)
-    {
-      case LSM6DS3TR_C_TRG_XL_GY_DRDY:
-        *val = LSM6DS3TR_C_TRG_XL_GY_DRDY;
-        break;
-
-      case LSM6DS3TR_C_TRG_STEP_DETECT:
-        *val = LSM6DS3TR_C_TRG_STEP_DETECT;
-        break;
-
-      case LSM6DS3TR_C_TRG_SH_DRDY:
-        *val = LSM6DS3TR_C_TRG_SH_DRDY;
-        break;
-
-      default:
-        *val = LSM6DS3TR_C_TRG_SH_ND;
-        break;
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief   Enable pedometer step counter and timestamp as 4th
-  *          FIFO data set.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of timer_pedo_fifo_en in reg FIFO_CTRL2
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_pedo_and_timestamp_batch_set(
-  stmdev_ctx_t *ctx,
-  uint8_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                             (uint8_t *)&fifo_ctrl2, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl2.timer_pedo_fifo_en = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                                (uint8_t *)&fifo_ctrl2, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable pedometer step counter and timestamp as 4th
-  *         FIFO data set.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of timer_pedo_fifo_en in reg FIFO_CTRL2
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_pedo_and_timestamp_batch_get(
-  stmdev_ctx_t *ctx,
-  uint8_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2,
-                             (uint8_t *)&fifo_ctrl2, 1);
-  *val = fifo_ctrl2.timer_pedo_fifo_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Selects Batching Data Rate (writing frequency in FIFO) for
-  *         accelerometer data.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of dec_fifo_xl in reg FIFO_CTRL3
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_xl_batch_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_dec_fifo_xl_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl3_t fifo_ctrl3;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3,
-                             (uint8_t *)&fifo_ctrl3, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl3.dec_fifo_xl = (uint8_t)val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3,
-                                (uint8_t *)&fifo_ctrl3, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Selects Batching Data Rate (writing frequency in FIFO) for
-  *         accelerometer data.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of dec_fifo_xl in reg FIFO_CTRL3
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_xl_batch_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_dec_fifo_xl_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl3_t fifo_ctrl3;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3,
-                             (uint8_t *)&fifo_ctrl3, 1);
-
-  switch (fifo_ctrl3.dec_fifo_xl)
-  {
-    case LSM6DS3TR_C_FIFO_XL_DISABLE:
-      *val = LSM6DS3TR_C_FIFO_XL_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_FIFO_XL_NO_DEC:
-      *val = LSM6DS3TR_C_FIFO_XL_NO_DEC;
-      break;
-
-    case LSM6DS3TR_C_FIFO_XL_DEC_2:
-      *val = LSM6DS3TR_C_FIFO_XL_DEC_2;
-      break;
-
-    case LSM6DS3TR_C_FIFO_XL_DEC_3:
-      *val = LSM6DS3TR_C_FIFO_XL_DEC_3;
-      break;
-
-    case LSM6DS3TR_C_FIFO_XL_DEC_4:
-      *val = LSM6DS3TR_C_FIFO_XL_DEC_4;
-      break;
-
-    case LSM6DS3TR_C_FIFO_XL_DEC_8:
-      *val = LSM6DS3TR_C_FIFO_XL_DEC_8;
-      break;
-
-    case LSM6DS3TR_C_FIFO_XL_DEC_16:
-      *val = LSM6DS3TR_C_FIFO_XL_DEC_16;
-      break;
-
-    case LSM6DS3TR_C_FIFO_XL_DEC_32:
-      *val = LSM6DS3TR_C_FIFO_XL_DEC_32;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_FIFO_XL_DEC_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Selects Batching Data Rate (writing frequency in FIFO)
-  *         for gyroscope data.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of dec_fifo_gyro in reg FIFO_CTRL3
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_gy_batch_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_dec_fifo_gyro_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl3_t fifo_ctrl3;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3,
-                             (uint8_t *)&fifo_ctrl3, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl3.dec_fifo_gyro = (uint8_t)val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3,
-                                (uint8_t *)&fifo_ctrl3, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Selects Batching Data Rate (writing frequency in FIFO)
-  *         for gyroscope data.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of dec_fifo_gyro in reg FIFO_CTRL3
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_gy_batch_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_dec_fifo_gyro_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl3_t fifo_ctrl3;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3,
-                             (uint8_t *)&fifo_ctrl3, 1);
-
-  switch (fifo_ctrl3.dec_fifo_gyro)
-  {
-    case LSM6DS3TR_C_FIFO_GY_DISABLE:
-      *val = LSM6DS3TR_C_FIFO_GY_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_FIFO_GY_NO_DEC:
-      *val = LSM6DS3TR_C_FIFO_GY_NO_DEC;
-      break;
-
-    case LSM6DS3TR_C_FIFO_GY_DEC_2:
-      *val = LSM6DS3TR_C_FIFO_GY_DEC_2;
-      break;
-
-    case LSM6DS3TR_C_FIFO_GY_DEC_3:
-      *val = LSM6DS3TR_C_FIFO_GY_DEC_3;
-      break;
-
-    case LSM6DS3TR_C_FIFO_GY_DEC_4:
-      *val = LSM6DS3TR_C_FIFO_GY_DEC_4;
-      break;
-
-    case LSM6DS3TR_C_FIFO_GY_DEC_8:
-      *val = LSM6DS3TR_C_FIFO_GY_DEC_8;
-      break;
-
-    case LSM6DS3TR_C_FIFO_GY_DEC_16:
-      *val = LSM6DS3TR_C_FIFO_GY_DEC_16;
-      break;
-
-    case LSM6DS3TR_C_FIFO_GY_DEC_32:
-      *val = LSM6DS3TR_C_FIFO_GY_DEC_32;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_FIFO_GY_DEC_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief   Selects Batching Data Rate (writing frequency in FIFO)
-  *          for third data set.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of dec_ds3_fifo in reg FIFO_CTRL4
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_dataset_3_batch_set(stmdev_ctx_t *ctx,
-                                             lsm6ds3tr_c_dec_ds3_fifo_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                             (uint8_t *)&fifo_ctrl4, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl4.dec_ds3_fifo = (uint8_t)val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                                (uint8_t *)&fifo_ctrl4, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief   Selects Batching Data Rate (writing frequency in FIFO)
-  *          for third data set.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of dec_ds3_fifo in reg FIFO_CTRL4
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_dataset_3_batch_get(stmdev_ctx_t *ctx,
-                                             lsm6ds3tr_c_dec_ds3_fifo_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                             (uint8_t *)&fifo_ctrl4, 1);
-
-  switch (fifo_ctrl4.dec_ds3_fifo)
-  {
-    case LSM6DS3TR_C_FIFO_DS3_DISABLE:
-      *val = LSM6DS3TR_C_FIFO_DS3_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS3_NO_DEC:
-      *val = LSM6DS3TR_C_FIFO_DS3_NO_DEC;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS3_DEC_2:
-      *val = LSM6DS3TR_C_FIFO_DS3_DEC_2;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS3_DEC_3:
-      *val = LSM6DS3TR_C_FIFO_DS3_DEC_3;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS3_DEC_4:
-      *val = LSM6DS3TR_C_FIFO_DS3_DEC_4;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS3_DEC_8:
-      *val = LSM6DS3TR_C_FIFO_DS3_DEC_8;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS3_DEC_16:
-      *val = LSM6DS3TR_C_FIFO_DS3_DEC_16;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS3_DEC_32:
-      *val = LSM6DS3TR_C_FIFO_DS3_DEC_32;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_FIFO_DS3_DEC_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief   Selects Batching Data Rate (writing frequency in FIFO)
-  *          for fourth data set.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of dec_ds4_fifo in reg FIFO_CTRL4
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_dataset_4_batch_set(stmdev_ctx_t *ctx,
-                                             lsm6ds3tr_c_dec_ds4_fifo_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                             (uint8_t *)&fifo_ctrl4, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl4.dec_ds4_fifo = (uint8_t)val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                                (uint8_t *)&fifo_ctrl4, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief   Selects Batching Data Rate (writing frequency in FIFO) for
-  *          fourth data set.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of dec_ds4_fifo in reg FIFO_CTRL4
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_dataset_4_batch_get(stmdev_ctx_t *ctx,
-                                             lsm6ds3tr_c_dec_ds4_fifo_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                             (uint8_t *)&fifo_ctrl4, 1);
-
-  switch (fifo_ctrl4.dec_ds4_fifo)
-  {
-    case LSM6DS3TR_C_FIFO_DS4_DISABLE:
-      *val = LSM6DS3TR_C_FIFO_DS4_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS4_NO_DEC:
-      *val = LSM6DS3TR_C_FIFO_DS4_NO_DEC;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS4_DEC_2:
-      *val = LSM6DS3TR_C_FIFO_DS4_DEC_2;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS4_DEC_3:
-      *val = LSM6DS3TR_C_FIFO_DS4_DEC_3;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS4_DEC_4:
-      *val = LSM6DS3TR_C_FIFO_DS4_DEC_4;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS4_DEC_8:
-      *val = LSM6DS3TR_C_FIFO_DS4_DEC_8;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS4_DEC_16:
-      *val = LSM6DS3TR_C_FIFO_DS4_DEC_16;
-      break;
-
-    case LSM6DS3TR_C_FIFO_DS4_DEC_32:
-      *val = LSM6DS3TR_C_FIFO_DS4_DEC_32;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_FIFO_DS4_DEC_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief   8-bit data storage in FIFO.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of only_high_data in reg FIFO_CTRL4
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_xl_gy_8bit_format_set(stmdev_ctx_t *ctx,
-                                               uint8_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                             (uint8_t *)&fifo_ctrl4, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl4.only_high_data = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                                (uint8_t *)&fifo_ctrl4, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  8-bit data storage in FIFO.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of only_high_data in reg FIFO_CTRL4
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_xl_gy_8bit_format_get(stmdev_ctx_t *ctx,
-                                               uint8_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                             (uint8_t *)&fifo_ctrl4, 1);
-  *val = fifo_ctrl4.only_high_data;
-
-  return ret;
-}
-
-/**
-  * @brief  Sensing chain FIFO stop values memorization at threshold
-  *         level.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of stop_on_fth in reg FIFO_CTRL4
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_stop_on_wtm_set(stmdev_ctx_t *ctx,
-                                         uint8_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                             (uint8_t *)&fifo_ctrl4, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl4.stop_on_fth = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                                (uint8_t *)&fifo_ctrl4, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Sensing chain FIFO stop values memorization at threshold
-  *         level.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of stop_on_fth in reg FIFO_CTRL4
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_stop_on_wtm_get(stmdev_ctx_t *ctx,
-                                         uint8_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4,
-                             (uint8_t *)&fifo_ctrl4, 1);
-  *val = fifo_ctrl4.stop_on_fth;
-
-  return ret;
-}
-
-/**
-  * @brief  FIFO mode selection.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of fifo_mode in reg FIFO_CTRL5
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_mode_set(stmdev_ctx_t *ctx,
-                                  lsm6ds3tr_c_fifo_mode_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl5_t fifo_ctrl5;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5,
-                             (uint8_t *)&fifo_ctrl5, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl5.fifo_mode = (uint8_t)val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5,
-                                (uint8_t *)&fifo_ctrl5, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  FIFO mode selection.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of fifo_mode in reg FIFO_CTRL5
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_mode_get(stmdev_ctx_t *ctx,
-                                  lsm6ds3tr_c_fifo_mode_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl5_t fifo_ctrl5;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5,
-                             (uint8_t *)&fifo_ctrl5, 1);
-
-  switch (fifo_ctrl5.fifo_mode)
-  {
-    case LSM6DS3TR_C_BYPASS_MODE:
-      *val = LSM6DS3TR_C_BYPASS_MODE;
-      break;
-
-    case LSM6DS3TR_C_FIFO_MODE:
-      *val = LSM6DS3TR_C_FIFO_MODE;
-      break;
-
-    case LSM6DS3TR_C_STREAM_TO_FIFO_MODE:
-      *val = LSM6DS3TR_C_STREAM_TO_FIFO_MODE;
-      break;
-
-    case LSM6DS3TR_C_BYPASS_TO_STREAM_MODE:
-      *val = LSM6DS3TR_C_BYPASS_TO_STREAM_MODE;
-      break;
-
-    case LSM6DS3TR_C_STREAM_MODE:
-      *val = LSM6DS3TR_C_STREAM_MODE;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_FIFO_MODE_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  FIFO ODR selection, setting FIFO_MODE also.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of odr_fifo in reg FIFO_CTRL5
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_data_rate_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_odr_fifo_t val)
-{
-  lsm6ds3tr_c_fifo_ctrl5_t fifo_ctrl5;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5,
-                             (uint8_t *)&fifo_ctrl5, 1);
-
-  if (ret == 0)
-  {
-    fifo_ctrl5.odr_fifo = (uint8_t)val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5,
-                                (uint8_t *)&fifo_ctrl5, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  FIFO ODR selection, setting FIFO_MODE also.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of odr_fifo in reg FIFO_CTRL5
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_fifo_data_rate_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_odr_fifo_t *val)
-{
-  lsm6ds3tr_c_fifo_ctrl5_t fifo_ctrl5;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5,
-                             (uint8_t *)&fifo_ctrl5, 1);
-
-  switch (fifo_ctrl5.odr_fifo)
-  {
-    case LSM6DS3TR_C_FIFO_DISABLE:
-      *val = LSM6DS3TR_C_FIFO_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_FIFO_12Hz5:
-      *val = LSM6DS3TR_C_FIFO_12Hz5;
-      break;
-
-    case LSM6DS3TR_C_FIFO_26Hz:
-      *val = LSM6DS3TR_C_FIFO_26Hz;
-      break;
-
-    case LSM6DS3TR_C_FIFO_52Hz:
-      *val = LSM6DS3TR_C_FIFO_52Hz;
-      break;
-
-    case LSM6DS3TR_C_FIFO_104Hz:
-      *val = LSM6DS3TR_C_FIFO_104Hz;
-      break;
-
-    case LSM6DS3TR_C_FIFO_208Hz:
-      *val = LSM6DS3TR_C_FIFO_208Hz;
-      break;
-
-    case LSM6DS3TR_C_FIFO_416Hz:
-      *val = LSM6DS3TR_C_FIFO_416Hz;
-      break;
-
-    case LSM6DS3TR_C_FIFO_833Hz:
-      *val = LSM6DS3TR_C_FIFO_833Hz;
-      break;
-
-    case LSM6DS3TR_C_FIFO_1k66Hz:
-      *val = LSM6DS3TR_C_FIFO_1k66Hz;
-      break;
-
-    case LSM6DS3TR_C_FIFO_3k33Hz:
-      *val = LSM6DS3TR_C_FIFO_3k33Hz;
-      break;
-
-    case LSM6DS3TR_C_FIFO_6k66Hz:
-      *val = LSM6DS3TR_C_FIFO_6k66Hz;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_FIFO_RATE_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_DEN_functionality
-  * @brief       This section groups all the functions concerning DEN
-  *              functionality.
-  * @{
-  *
-  */
-
-/**
-  * @brief  DEN active level configuration.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of den_lh in reg CTRL5_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_polarity_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_den_lh_t val)
-{
-  lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                             (uint8_t *)&ctrl5_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl5_c.den_lh = (uint8_t)val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                                (uint8_t *)&ctrl5_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  DEN active level configuration.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of den_lh in reg CTRL5_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_polarity_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_den_lh_t *val)
-{
-  lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C,
-                             (uint8_t *)&ctrl5_c, 1);
-
-  switch (ctrl5_c.den_lh)
-  {
-    case LSM6DS3TR_C_DEN_ACT_LOW:
-      *val = LSM6DS3TR_C_DEN_ACT_LOW;
-      break;
-
-    case LSM6DS3TR_C_DEN_ACT_HIGH:
-      *val = LSM6DS3TR_C_DEN_ACT_HIGH;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_DEN_POL_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  DEN functionality marking mode[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of den_mode in reg CTRL6_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_mode_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_den_mode_t val)
-{
-  lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                             (uint8_t *)&ctrl6_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl6_c.den_mode = (uint8_t)val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                                (uint8_t *)&ctrl6_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  DEN functionality marking mode[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of den_mode in reg CTRL6_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_mode_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_den_mode_t *val)
-{
-  lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C,
-                             (uint8_t *)&ctrl6_c, 1);
-
-  switch (ctrl6_c.den_mode)
-  {
-    case LSM6DS3TR_C_DEN_DISABLE:
-      *val = LSM6DS3TR_C_DEN_DISABLE;
-      break;
-
-    case LSM6DS3TR_C_LEVEL_LETCHED:
-      *val = LSM6DS3TR_C_LEVEL_LETCHED;
-      break;
-
-    case LSM6DS3TR_C_LEVEL_TRIGGER:
-      *val = LSM6DS3TR_C_LEVEL_TRIGGER;
-      break;
-
-    case LSM6DS3TR_C_EDGE_TRIGGER:
-      *val = LSM6DS3TR_C_EDGE_TRIGGER;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_DEN_MODE_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Extend DEN functionality to accelerometer sensor.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of den_xl_g in reg CTRL9_XL
-  *                             and den_xl_en in CTRL4_C.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_enable_set(stmdev_ctx_t *ctx,
-                                   lsm6ds3tr_c_den_xl_en_t val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                             (uint8_t *)&ctrl9_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl9_xl.den_xl_g = (uint8_t)val & 0x01U;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                                (uint8_t *)&ctrl9_xl, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                                 (uint8_t *)&ctrl4_c, 1);
-
-      if (ret == 0)
-      {
-        ctrl4_c.den_xl_en = (uint8_t)val & 0x02U;
-        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                                    (uint8_t *)&ctrl4_c, 1);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Extend DEN functionality to accelerometer sensor. [get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of den_xl_g in reg CTRL9_XL
-  *                             and den_xl_en in CTRL4_C.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_enable_get(stmdev_ctx_t *ctx,
-                                   lsm6ds3tr_c_den_xl_en_t *val)
-{
-  lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
-  lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C,
-                             (uint8_t *)&ctrl4_c, 1);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                               (uint8_t *)&ctrl9_xl, 1);
-
-    switch ((ctrl4_c.den_xl_en << 1) + ctrl9_xl.den_xl_g)
-    {
-      case LSM6DS3TR_C_STAMP_IN_GY_DATA:
-        *val = LSM6DS3TR_C_STAMP_IN_GY_DATA;
-        break;
-
-      case LSM6DS3TR_C_STAMP_IN_XL_DATA:
-        *val = LSM6DS3TR_C_STAMP_IN_XL_DATA;
-        break;
-
-      case LSM6DS3TR_C_STAMP_IN_GY_XL_DATA:
-        *val = LSM6DS3TR_C_STAMP_IN_GY_XL_DATA;
-        break;
-
-      default:
-        *val = LSM6DS3TR_C_DEN_STAMP_ND;
-        break;
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  DEN value stored in LSB of Z-axis.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of den_z in reg CTRL9_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_mark_axis_z_set(stmdev_ctx_t *ctx,
-                                        uint8_t val)
-{
-  lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                             (uint8_t *)&ctrl9_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl9_xl.den_z = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                                (uint8_t *)&ctrl9_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  DEN value stored in LSB of Z-axis.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of den_z in reg CTRL9_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_mark_axis_z_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                             (uint8_t *)&ctrl9_xl, 1);
-  *val = ctrl9_xl.den_z;
-
-  return ret;
-}
-
-/**
-  * @brief  DEN value stored in LSB of Y-axis.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of den_y in reg CTRL9_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_mark_axis_y_set(stmdev_ctx_t *ctx,
-                                        uint8_t val)
-{
-  lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                             (uint8_t *)&ctrl9_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl9_xl.den_y = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                                (uint8_t *)&ctrl9_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  DEN value stored in LSB of Y-axis.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of den_y in reg CTRL9_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_mark_axis_y_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                             (uint8_t *)&ctrl9_xl, 1);
-  *val = ctrl9_xl.den_y;
-
-  return ret;
-}
-
-/**
-  * @brief  DEN value stored in LSB of X-axis.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of den_x in reg CTRL9_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_mark_axis_x_set(stmdev_ctx_t *ctx,
-                                        uint8_t val)
-{
-  lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                             (uint8_t *)&ctrl9_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl9_xl.den_x = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                                (uint8_t *)&ctrl9_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  DEN value stored in LSB of X-axis.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of den_x in reg CTRL9_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_den_mark_axis_x_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                             (uint8_t *)&ctrl9_xl, 1);
-  *val = ctrl9_xl.den_x;
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_Pedometer
-  * @brief       This section groups all the functions that manage pedometer.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Reset pedometer step counter.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of pedo_rst_step in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_step_reset_set(stmdev_ctx_t *ctx,
-                                        uint8_t val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl10_c.pedo_rst_step = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                                (uint8_t *)&ctrl10_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Reset pedometer step counter.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of pedo_rst_step in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_step_reset_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-  *val = ctrl10_c.pedo_rst_step;
-
-  return ret;
-}
-
-/**
-  * @brief  Enable pedometer algorithm.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of pedo_en in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_sens_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl10_c.pedo_en = val;
-
-    if (val != 0x00U)
-    {
-      ctrl10_c.func_en = val;
-    }
-
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                                (uint8_t *)&ctrl10_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  pedo_sens:   Enable pedometer algorithm.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of pedo_en in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_sens_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-  *val = ctrl10_c.pedo_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Minimum threshold to detect a peak. Default is 10h.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of ths_min in reg
-  *                      CONFIG_PEDO_THS_MIN
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_threshold_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_config_pedo_ths_min_t config_pedo_ths_min;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN,
-                               (uint8_t *)&config_pedo_ths_min, 1);
-
-    if (ret == 0)
-    {
-      config_pedo_ths_min.ths_min = val;
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN,
-                                  (uint8_t *)&config_pedo_ths_min, 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Minimum threshold to detect a peak. Default is 10h.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of ths_min in reg  CONFIG_PEDO_THS_MIN
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_threshold_get(stmdev_ctx_t *ctx,
-                                       uint8_t *val)
-{
-  lsm6ds3tr_c_config_pedo_ths_min_t config_pedo_ths_min;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN,
-                               (uint8_t *)&config_pedo_ths_min, 1);
-
-    if (ret == 0)
-    {
-      *val =  config_pedo_ths_min.ths_min;
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  pedo_full_scale:   Pedometer data range.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of pedo_fs in
-  *                            reg CONFIG_PEDO_THS_MIN
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_full_scale_set(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_pedo_fs_t val)
-{
-  lsm6ds3tr_c_config_pedo_ths_min_t config_pedo_ths_min;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN,
-                               (uint8_t *)&config_pedo_ths_min, 1);
-
-    if (ret == 0)
-    {
-      config_pedo_ths_min.pedo_fs = (uint8_t) val;
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN,
-                                  (uint8_t *)&config_pedo_ths_min, 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Pedometer data range.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of pedo_fs in
-  *                            reg CONFIG_PEDO_THS_MIN
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_full_scale_get(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_pedo_fs_t *val)
-{
-  lsm6ds3tr_c_config_pedo_ths_min_t config_pedo_ths_min;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN,
-                               (uint8_t *)&config_pedo_ths_min, 1);
-
-    if (ret == 0)
-    {
-      switch (config_pedo_ths_min.pedo_fs)
-      {
-        case LSM6DS3TR_C_PEDO_AT_2g:
-          *val = LSM6DS3TR_C_PEDO_AT_2g;
-          break;
-
-        case LSM6DS3TR_C_PEDO_AT_4g:
-          *val = LSM6DS3TR_C_PEDO_AT_4g;
-          break;
-
-        default:
-          *val = LSM6DS3TR_C_PEDO_FS_ND;
-          break;
-      }
-
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Pedometer debounce configuration register (r/w).[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of deb_step in reg PEDO_DEB_REG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_debounce_steps_set(stmdev_ctx_t *ctx,
-                                            uint8_t val)
-{
-  lsm6ds3tr_c_pedo_deb_reg_t pedo_deb_reg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG,
-                               (uint8_t *)&pedo_deb_reg, 1);
-
-    if (ret == 0)
-    {
-      pedo_deb_reg.deb_step = val;
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG,
-                                  (uint8_t *)&pedo_deb_reg, 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Pedometer debounce configuration register (r/w).[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of deb_step in reg PEDO_DEB_REG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_debounce_steps_get(stmdev_ctx_t *ctx,
-                                            uint8_t *val)
-{
-  lsm6ds3tr_c_pedo_deb_reg_t pedo_deb_reg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG,
-                               (uint8_t *)&pedo_deb_reg, 1);
-
-    if (ret == 0)
-    {
-      *val = pedo_deb_reg.deb_step;
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Debounce time. If the time between two consecutive steps is
-  *         greater than  DEB_TIME*80ms, the debouncer is reactivated.
-  *         Default value: 01101[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of deb_time in reg PEDO_DEB_REG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_timeout_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_pedo_deb_reg_t pedo_deb_reg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG,
-                               (uint8_t *)&pedo_deb_reg, 1);
-
-    if (ret == 0)
-    {
-      pedo_deb_reg.deb_time = val;
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG,
-                                  (uint8_t *)&pedo_deb_reg, 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Debounce time. If the time between two consecutive steps is
-  *         greater than  DEB_TIME*80ms, the debouncer is reactivated.
-  *         Default value: 01101[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of deb_time in reg PEDO_DEB_REG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_timeout_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_pedo_deb_reg_t pedo_deb_reg;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG,
-                               (uint8_t *)&pedo_deb_reg, 1);
-
-    if (ret == 0)
-    {
-      *val = pedo_deb_reg.deb_time;
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Time period register for step detection on delta time (r/w).[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that contains data to write
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_steps_period_set(stmdev_ctx_t *ctx,
-                                          uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_STEP_COUNT_DELTA, buff, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Time period register for step detection on delta time (r/w).[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_pedo_steps_period_get(stmdev_ctx_t *ctx,
-                                          uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STEP_COUNT_DELTA, buff, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_significant_motion
-  * @brief       This section groups all the functions that manage the
-  *              significant motion detection.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Enable significant motion detection function.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of sign_motion_en in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_motion_sens_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl10_c.sign_motion_en = val;
-
-    if (val != 0x00U)
-    {
-      ctrl10_c.func_en = val;
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                                  (uint8_t *)&ctrl10_c, 1);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable significant motion detection function.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of sign_motion_en in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_motion_sens_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-  *val = ctrl10_c.sign_motion_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Significant motion threshold.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that store significant motion threshold.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_motion_threshold_set(stmdev_ctx_t *ctx,
-                                         uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SM_THS, buff, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Significant motion threshold.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that store significant motion threshold.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_motion_threshold_get(stmdev_ctx_t *ctx,
-                                         uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SM_THS, buff, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_tilt_detection
-  * @brief       This section groups all the functions that manage the tilt
-  *              event detection.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Enable tilt calculation.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tilt_en in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tilt_sens_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl10_c.tilt_en = val;
-
-    if (val != 0x00U)
-    {
-      ctrl10_c.func_en = val;
-    }
-
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                                (uint8_t *)&ctrl10_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable tilt calculation.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tilt_en in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tilt_sens_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-  *val = ctrl10_c.tilt_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Enable tilt calculation.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tilt_en in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_wrist_tilt_sens_set(stmdev_ctx_t *ctx,
-                                        uint8_t val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl10_c.wrist_tilt_en = val;
-
-    if (val != 0x00U)
-    {
-      ctrl10_c.func_en = val;
-    }
-
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                                (uint8_t *)&ctrl10_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable tilt calculation.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tilt_en in reg CTRL10_C
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_wrist_tilt_sens_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-  *val = ctrl10_c.wrist_tilt_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Absolute Wrist Tilt latency register (r/w).
-  *         Absolute wrist tilt latency parameters.
-  *         1 LSB = 40 ms. Default value: 0Fh (600 ms).[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that contains data to write
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tilt_latency_set(stmdev_ctx_t *ctx, uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_LAT, buff, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Absolute Wrist Tilt latency register (r/w).
-  *         Absolute wrist tilt latency parameters.
-  *         1 LSB = 40 ms. Default value: 0Fh (600 ms).[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tilt_latency_get(stmdev_ctx_t *ctx, uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_LAT, buff, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Absolute Wrist Tilt threshold register(r/w).
-  *         Absolute wrist tilt threshold parameters.
-  *         1 LSB = 15.625 mg.Default value: 20h (500 mg).[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that contains data to write
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tilt_threshold_set(stmdev_ctx_t *ctx,
-                                       uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_THS, buff, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Absolute Wrist Tilt threshold register(r/w).
-  *         Absolute wrist tilt threshold parameters.
-  *         1 LSB = 15.625 mg.Default value: 20h (500 mg).[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tilt_threshold_get(stmdev_ctx_t *ctx,
-                                       uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_THS, buff, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Absolute Wrist Tilt mask register (r/w).[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Registers A_WRIST_TILT_MASK
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tilt_src_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_a_wrist_tilt_mask_t *val)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_MASK,
-                               (uint8_t *) val, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Absolute Wrist Tilt mask register (r/w).[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Registers A_WRIST_TILT_MASK
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_tilt_src_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_a_wrist_tilt_mask_t *val)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_MASK,
-                               (uint8_t *) val, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_ magnetometer_sensor
-  * @brief       This section groups all the functions that manage additional
-  *              magnetometer sensor.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Enable soft-iron correction algorithm for magnetometer.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of soft_en in reg CTRL9_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mag_soft_iron_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                             (uint8_t *)&ctrl9_xl, 1);
-
-  if (ret == 0)
-  {
-    ctrl9_xl.soft_en = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                                (uint8_t *)&ctrl9_xl, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable soft-iron correction algorithm for magnetometer.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of soft_en in reg CTRL9_XL
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mag_soft_iron_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL,
-                             (uint8_t *)&ctrl9_xl, 1);
-  *val = ctrl9_xl.soft_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Enable hard-iron correction algorithm for magnetometer.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of iron_en in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mag_hard_iron_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-
-  if (ret == 0)
-  {
-    master_config.iron_en = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                                (uint8_t *)&master_config, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                                 (uint8_t *)&ctrl10_c, 1);
-
-      if (ret == 0)
-      {
-        if (val != 0x00U)
-        {
-          ctrl10_c.func_en = val;
-        }
-
-        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                                    (uint8_t *)&ctrl10_c, 1);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Enable hard-iron correction algorithm for magnetometer.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of iron_en in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mag_hard_iron_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-  *val = master_config.iron_en;
-
-  return ret;
-}
-
-/**
-  * @brief  Soft iron 3x3 matrix. Value are expressed in sign-module format.
-  *         (Es. SVVVVVVVb where S is the sign 0/+1/- and V is the value).[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that contains data to write
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mag_soft_iron_mat_set(stmdev_ctx_t *ctx,
-                                          uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MAG_SI_XX, buff, 9);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Soft iron 3x3 matrix. Value are expressed in sign-module format.
-  *         (Es. SVVVVVVVb where S is the sign 0/+1/- and V is the value).[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mag_soft_iron_mat_get(stmdev_ctx_t *ctx,
-                                          uint8_t *buff)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MAG_SI_XX, buff, 9);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Offset for hard-iron compensation register (r/w). The value is
-  *         expressed as a 16-bit word in two’s complement.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that contains data to write
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mag_offset_set(stmdev_ctx_t *ctx, int16_t *val)
-{
-  uint8_t buff[6];
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    buff[1] = (uint8_t)((uint16_t)val[0] / 256U);
-    buff[0] = (uint8_t)((uint16_t)val[0] - (buff[1] * 256U));
-    buff[3] = (uint8_t)((uint16_t)val[1] / 256U);
-    buff[2] = (uint8_t)((uint16_t)val[1] - (buff[3] * 256U));
-    buff[5] = (uint8_t)((uint16_t)val[2] / 256U);
-    buff[4] = (uint8_t)((uint16_t)val[2] - (buff[5] * 256U));
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MAG_OFFX_L, buff, 6);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Offset for hard-iron compensation register(r/w).
-  *         The value is expressed as a 16-bit word in two’s complement.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  buff   Buffer that stores data read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_mag_offset_get(stmdev_ctx_t *ctx, int16_t *val)
-{
-  uint8_t buff[6];
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MAG_OFFX_L, buff, 6);
-
-    if (ret == 0)
-    {
-      val[0] = (int16_t)buff[1];
-      val[0] = (val[0] * 256) + (int16_t)buff[0];
-      val[1] = (int16_t)buff[3];
-      val[1] = (val[1] * 256) + (int16_t)buff[2];
-      val[2] = (int16_t)buff[5];
-      val[2] = (val[2] * 256) + (int16_t)buff[4];
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @defgroup    LSM6DS3TR_C_Sensor_hub
-  * @brief       This section groups all the functions that manage the sensor
-  *              hub functionality.
-  * @{
-  *
-  */
-
-/**
-  * @brief  Enable function.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values func_en
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_func_en_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                             (uint8_t *)&ctrl10_c, 1);
-
-  if (ret == 0)
-  {
-    ctrl10_c.func_en = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C,
-                                (uint8_t *)&ctrl10_c, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Sensor synchronization time frame with the step of 500 ms and
-  *         full range of 5s. Unsigned 8-bit.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tph in reg SENSOR_SYNC_TIME_FRAME
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_sync_sens_frame_set(stmdev_ctx_t *ctx,
-                                           uint8_t val)
-{
-  lsm6ds3tr_c_sensor_sync_time_frame_t sensor_sync_time_frame;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SENSOR_SYNC_TIME_FRAME,
-                             (uint8_t *)&sensor_sync_time_frame, 1);
-
-  if (ret == 0)
-  {
-    sensor_sync_time_frame.tph = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SENSOR_SYNC_TIME_FRAME,
-                                (uint8_t *)&sensor_sync_time_frame, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Sensor synchronization time frame with the step of 500 ms and
-  *         full range of 5s. Unsigned 8-bit.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of tph in reg  SENSOR_SYNC_TIME_FRAME
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_sync_sens_frame_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val)
-{
-  lsm6ds3tr_c_sensor_sync_time_frame_t sensor_sync_time_frame;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SENSOR_SYNC_TIME_FRAME,
-                             (uint8_t *)&sensor_sync_time_frame, 1);
-  *val =  sensor_sync_time_frame.tph;
-
-  return ret;
-}
-
-/**
-  * @brief  Resolution ratio of error code for sensor synchronization.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of rr in reg  SENSOR_SYNC_RES_RATIO
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_sync_sens_ratio_set(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_rr_t val)
-{
-  lsm6ds3tr_c_sensor_sync_res_ratio_t sensor_sync_res_ratio;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SENSOR_SYNC_RES_RATIO,
-                             (uint8_t *)&sensor_sync_res_ratio, 1);
-
-  if (ret == 0)
-  {
-    sensor_sync_res_ratio.rr = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SENSOR_SYNC_RES_RATIO,
-                                (uint8_t *)&sensor_sync_res_ratio, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Resolution ratio of error code for sensor synchronization.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of rr in reg  SENSOR_SYNC_RES_RATIO
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_sync_sens_ratio_get(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_rr_t *val)
-{
-  lsm6ds3tr_c_sensor_sync_res_ratio_t sensor_sync_res_ratio;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SENSOR_SYNC_RES_RATIO,
-                             (uint8_t *)&sensor_sync_res_ratio, 1);
-
-  switch (sensor_sync_res_ratio.rr)
-  {
-    case LSM6DS3TR_C_RES_RATIO_2_11:
-      *val = LSM6DS3TR_C_RES_RATIO_2_11;
-      break;
-
-    case LSM6DS3TR_C_RES_RATIO_2_12:
-      *val = LSM6DS3TR_C_RES_RATIO_2_12;
-      break;
-
-    case LSM6DS3TR_C_RES_RATIO_2_13:
-      *val = LSM6DS3TR_C_RES_RATIO_2_13;
-      break;
-
-    case LSM6DS3TR_C_RES_RATIO_2_14:
-      *val = LSM6DS3TR_C_RES_RATIO_2_14;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_RES_RATIO_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Sensor hub I2C master enable.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of master_on in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_master_set(stmdev_ctx_t *ctx, uint8_t val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-
-  if (ret == 0)
-  {
-    master_config.master_on = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                                (uint8_t *)&master_config, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Sensor hub I2C master enable.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of master_on in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_master_get(stmdev_ctx_t *ctx, uint8_t *val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-  *val = master_config.master_on;
-
-  return ret;
-}
-
-/**
-  * @brief  I2C interface pass-through.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of pass_through_mode in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_pass_through_set(stmdev_ctx_t *ctx,
-                                        uint8_t val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-
-  if (ret == 0)
-  {
-    master_config.pass_through_mode = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                                (uint8_t *)&master_config, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  I2C interface pass-through.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of pass_through_mode in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_pass_through_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-  *val = master_config.pass_through_mode;
-
-  return ret;
-}
-
-/**
-  * @brief  Master I2C pull-up enable/disable.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of pull_up_en in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_pin_mode_set(stmdev_ctx_t *ctx,
-                                    lsm6ds3tr_c_pull_up_en_t val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-
-  if (ret == 0)
-  {
-    master_config.pull_up_en = (uint8_t) val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                                (uint8_t *)&master_config, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Master I2C pull-up enable/disable.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of pull_up_en in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_pin_mode_get(stmdev_ctx_t *ctx,
-                                    lsm6ds3tr_c_pull_up_en_t *val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-
-  switch (master_config.pull_up_en)
-  {
-    case LSM6DS3TR_C_EXT_PULL_UP:
-      *val = LSM6DS3TR_C_EXT_PULL_UP;
-      break;
-
-    case LSM6DS3TR_C_INTERNAL_PULL_UP:
-      *val = LSM6DS3TR_C_INTERNAL_PULL_UP;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_SH_PIN_MODE;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Sensor hub trigger signal selection.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of start_config in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_syncro_mode_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_start_config_t val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-
-  if (ret == 0)
-  {
-    master_config.start_config = (uint8_t)val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                                (uint8_t *)&master_config, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Sensor hub trigger signal selection.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of start_config in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_syncro_mode_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_start_config_t *val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-
-  switch (master_config.start_config)
-  {
-    case LSM6DS3TR_C_XL_GY_DRDY:
-      *val = LSM6DS3TR_C_XL_GY_DRDY;
-      break;
-
-    case LSM6DS3TR_C_EXT_ON_INT2_PIN:
-      *val = LSM6DS3TR_C_EXT_ON_INT2_PIN;
-      break;
-
-    default:
-      *val = LSM6DS3TR_C_SH_SYNCRO_ND;
-      break;
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Manage the Master DRDY signal on INT1 pad.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of drdy_on_int1 in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_drdy_on_int1_set(stmdev_ctx_t *ctx,
-                                        uint8_t val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-
-  if (ret == 0)
-  {
-    master_config.drdy_on_int1 = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                                (uint8_t *)&master_config, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Manage the Master DRDY signal on INT1 pad.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of drdy_on_int1 in reg MASTER_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_drdy_on_int1_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val)
-{
-  lsm6ds3tr_c_master_config_t master_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG,
-                             (uint8_t *)&master_config, 1);
-  *val = master_config.drdy_on_int1;
-
-  return ret;
-}
-
-/**
-  * @brief  Sensor hub output registers.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Structure of registers from SENSORHUB1_REG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_read_data_raw_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_emb_sh_read_t *val)
-{
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SENSORHUB1_REG,
-                             (uint8_t *) & (val->sh_byte_1), 12);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SENSORHUB13_REG,
-                               (uint8_t *) & (val->sh_byte_13), 6);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Master command code used for stamping for sensor sync.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of master_cmd_code in
-  *                reg MASTER_CMD_CODE
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_cmd_sens_sync_set(stmdev_ctx_t *ctx,
-                                         uint8_t val)
-{
-  lsm6ds3tr_c_master_cmd_code_t master_cmd_code;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CMD_CODE,
-                             (uint8_t *)&master_cmd_code, 1);
-
-  if (ret == 0)
-  {
-    master_cmd_code.master_cmd_code = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CMD_CODE,
-                                (uint8_t *)&master_cmd_code, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Master command code used for stamping for sensor sync.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of master_cmd_code in
-  *                reg MASTER_CMD_CODE
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_cmd_sens_sync_get(stmdev_ctx_t *ctx,
-                                         uint8_t *val)
-{
-  lsm6ds3tr_c_master_cmd_code_t master_cmd_code;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CMD_CODE,
-                             (uint8_t *)&master_cmd_code, 1);
-  *val = master_cmd_code.master_cmd_code;
-
-  return ret;
-}
-
-/**
-  * @brief  Error code used for sensor synchronization.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of error_code in
-  *                reg SENS_SYNC_SPI_ERROR_CODE.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_spi_sync_error_set(stmdev_ctx_t *ctx,
-                                          uint8_t val)
-{
-  lsm6ds3tr_c_sens_sync_spi_error_code_t sens_sync_spi_error_code;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SENS_SYNC_SPI_ERROR_CODE,
-                             (uint8_t *)&sens_sync_spi_error_code, 1);
-
-  if (ret == 0)
-  {
-    sens_sync_spi_error_code.error_code = val;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SENS_SYNC_SPI_ERROR_CODE,
-                                (uint8_t *)&sens_sync_spi_error_code, 1);
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Error code used for sensor synchronization.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of error_code in
-  *                reg SENS_SYNC_SPI_ERROR_CODE.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_spi_sync_error_get(stmdev_ctx_t *ctx,
-                                          uint8_t *val)
-{
-  lsm6ds3tr_c_sens_sync_spi_error_code_t sens_sync_spi_error_code;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SENS_SYNC_SPI_ERROR_CODE,
-                             (uint8_t *)&sens_sync_spi_error_code, 1);
-  *val =  sens_sync_spi_error_code.error_code;
-
-  return ret;
-}
-
-/**
-  * @brief   Number of external sensors to be read by the sensor hub.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of aux_sens_on in reg SLAVE0_CONFIG.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_num_of_dev_connected_set(stmdev_ctx_t *ctx,
-                                                lsm6ds3tr_c_aux_sens_on_t val)
-{
-  lsm6ds3tr_c_slave0_config_t slave0_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG,
-                               (uint8_t *)&slave0_config, 1);
-
-    if (ret == 0)
-    {
-      slave0_config.aux_sens_on = (uint8_t) val;
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG,
-                                  (uint8_t *)&slave0_config, 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief   Number of external sensors to be read by the sensor hub.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of aux_sens_on in reg SLAVE0_CONFIG.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_num_of_dev_connected_get(stmdev_ctx_t *ctx,
-                                                lsm6ds3tr_c_aux_sens_on_t *val)
-{
-  lsm6ds3tr_c_slave0_config_t slave0_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG,
-                               (uint8_t *)&slave0_config, 1);
-
-    if (ret == 0)
-    {
-      switch (slave0_config.aux_sens_on)
-      {
-        case LSM6DS3TR_C_SLV_0:
-          *val = LSM6DS3TR_C_SLV_0;
-          break;
-
-        case LSM6DS3TR_C_SLV_0_1:
-          *val = LSM6DS3TR_C_SLV_0_1;
-          break;
-
-        case LSM6DS3TR_C_SLV_0_1_2:
-          *val = LSM6DS3TR_C_SLV_0_1_2;
-          break;
-
-        case LSM6DS3TR_C_SLV_0_1_2_3:
-          *val = LSM6DS3TR_C_SLV_0_1_2_3;
-          break;
-
-        default:
-          *val = LSM6DS3TR_C_SLV_EN_ND;
-          break;
-      }
-
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Configure slave 0 for perform a write.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Structure that contain:
-  *                  - uint8_t slv_add;    8 bit i2c device address
-  *                  - uint8_t slv_subadd; 8 bit register device address
-  *                  - uint8_t slv_data;   8 bit data to write
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_cfg_write(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_sh_cfg_write_t *val)
-{
-  lsm6ds3tr_c_slv0_add_t slv0_add;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    slv0_add.slave0_add = val->slv0_add;
-    slv0_add.rw_0 = 0;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV0_ADD,
-                                (uint8_t *)&slv0_add, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV0_SUBADD,
-                                  &(val->slv0_subadd), 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_write_reg(ctx,
-                                    LSM6DS3TR_C_DATAWRITE_SRC_MODE_SUB_SLV0,
-                                    &(val->slv0_data), 1);
-
-        if (ret == 0)
-        {
-          ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-        }
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Configure slave 0 for perform a read.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Structure that contain:
-  *                  - uint8_t slv_add;    8 bit i2c device address
-  *                  - uint8_t slv_subadd; 8 bit register device address
-  *                  - uint8_t slv_len;    num of bit to read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slv0_cfg_read(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sh_cfg_read_t *val)
-{
-  lsm6ds3tr_c_slave0_config_t slave0_config;
-  lsm6ds3tr_c_slv0_add_t slv0_add;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    slv0_add.slave0_add = val->slv_add;
-    slv0_add.rw_0 = 1;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV0_ADD,
-                                (uint8_t *)&slv0_add, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV0_SUBADD,
-                                  &(val->slv_subadd), 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG,
-                                   (uint8_t *)&slave0_config, 1);
-        slave0_config.slave0_numop = val->slv_len;
-
-        if (ret == 0)
-        {
-          ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG,
-                                      (uint8_t *)&slave0_config, 1);
-
-          if (ret == 0)
-          {
-            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-          }
-        }
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Configure slave 1 for perform a read.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Structure that contain:
-  *                  - uint8_t slv_add;    8 bit i2c device address
-  *                  - uint8_t slv_subadd; 8 bit register device address
-  *                  - uint8_t slv_len;    num of bit to read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slv1_cfg_read(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sh_cfg_read_t *val)
-{
-  lsm6ds3tr_c_slave1_config_t slave1_config;
-  lsm6ds3tr_c_slv1_add_t slv1_add;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    slv1_add.slave1_add  = val->slv_add;
-    slv1_add.r_1 = 1;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV1_ADD,
-                                (uint8_t *)&slv1_add, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV1_SUBADD,
-                                  &(val->slv_subadd), 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG,
-                                   (uint8_t *)&slave1_config, 1);
-        slave1_config.slave1_numop = val->slv_len;
-
-        if (ret == 0)
-        {
-          ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG,
-                                      (uint8_t *)&slave1_config, 1);
-
-          if (ret == 0)
-          {
-            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-          }
-        }
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Configure slave 2 for perform a read.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Structure that contain:
-  *                  - uint8_t slv_add;    8 bit i2c device address
-  *                  - uint8_t slv_subadd; 8 bit register device address
-  *                  - uint8_t slv_len;    num of bit to read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slv2_cfg_read(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sh_cfg_read_t *val)
-{
-  lsm6ds3tr_c_slv2_add_t slv2_add;
-  lsm6ds3tr_c_slave2_config_t slave2_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    slv2_add.slave2_add  = val->slv_add;
-    slv2_add.r_2 = 1;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV2_ADD,
-                                (uint8_t *)&slv2_add, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV2_SUBADD,
-                                  &(val->slv_subadd), 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE2_CONFIG,
-                                   (uint8_t *)&slave2_config, 1);
-
-        if (ret == 0)
-        {
-          slave2_config.slave2_numop = val->slv_len;
-          ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE2_CONFIG,
-                                      (uint8_t *)&slave2_config, 1);
-
-          if (ret == 0)
-          {
-            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-          }
-        }
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Configure slave 3 for perform a read.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Structure that contain:
-  *                  - uint8_t slv_add;    8 bit i2c device address
-  *                  - uint8_t slv_subadd; 8 bit register device address
-  *                  - uint8_t slv_len;    num of bit to read
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slv3_cfg_read(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sh_cfg_read_t *val)
-{
-  lsm6ds3tr_c_slave3_config_t slave3_config;
-  lsm6ds3tr_c_slv3_add_t slv3_add;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    slv3_add.slave3_add  = val->slv_add;
-    slv3_add.r_3 = 1;
-    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV3_ADD,
-                                (uint8_t *)&slv3_add, 1);
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV3_SUBADD,
-                                  (uint8_t *) & (val->slv_subadd), 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE3_CONFIG,
-                                   (uint8_t *)&slave3_config, 1);
-
-        if (ret == 0)
-        {
-          slave3_config.slave3_numop = val->slv_len;
-          ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE3_CONFIG,
-                                      (uint8_t *)&slave3_config, 1);
-
-          if (ret == 0)
-          {
-            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-          }
-        }
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Decimation of read operation on Slave 0 starting from the
-  *         sensor hub trigger.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of slave0_rate in reg SLAVE0_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slave_0_dec_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave0_rate_t val)
-{
-  lsm6ds3tr_c_slave0_config_t slave0_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG,
-                               (uint8_t *)&slave0_config, 1);
-
-    if (ret == 0)
-    {
-      slave0_config.slave0_rate = (uint8_t) val;
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG,
-                                  (uint8_t *)&slave0_config, 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Decimation of read operation on Slave 0 starting from the
-  *         sensor hub trigger.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of slave0_rate in reg SLAVE0_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slave_0_dec_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave0_rate_t *val)
-{
-  lsm6ds3tr_c_slave0_config_t slave0_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG,
-                               (uint8_t *)&slave0_config, 1);
-
-    if (ret == 0)
-    {
-      switch (slave0_config.slave0_rate)
-      {
-        case LSM6DS3TR_C_SL0_NO_DEC:
-          *val = LSM6DS3TR_C_SL0_NO_DEC;
-          break;
-
-        case LSM6DS3TR_C_SL0_DEC_2:
-          *val = LSM6DS3TR_C_SL0_DEC_2;
-          break;
-
-        case LSM6DS3TR_C_SL0_DEC_4:
-          *val = LSM6DS3TR_C_SL0_DEC_4;
-          break;
-
-        case LSM6DS3TR_C_SL0_DEC_8:
-          *val = LSM6DS3TR_C_SL0_DEC_8;
-          break;
-
-        default:
-          *val = LSM6DS3TR_C_SL0_DEC_ND;
-          break;
-      }
-
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Slave 0 write operation is performed only at the first sensor
-  *         hub cycle.
-  *         This is effective if the Aux_sens_on[1:0] field in
-  *         SLAVE0_CONFIG(04h) is set to a value other than 00.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of write_once in reg SLAVE1_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_write_mode_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_write_once_t val)
-{
-  lsm6ds3tr_c_slave1_config_t slave1_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG,
-                               (uint8_t *)&slave1_config, 1);
-    slave1_config.write_once = (uint8_t) val;
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG,
-                                  (uint8_t *)&slave1_config, 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Slave 0 write operation is performed only at the first sensor
-  *         hub cycle.
-  *         This is effective if the Aux_sens_on[1:0] field in
-  *         SLAVE0_CONFIG(04h) is set to a value other than 00.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of write_once in reg SLAVE1_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_write_mode_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_write_once_t *val)
-{
-  lsm6ds3tr_c_slave1_config_t slave1_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG,
-                               (uint8_t *)&slave1_config, 1);
-
-    if (ret == 0)
-    {
-      switch (slave1_config.write_once)
-      {
-        case LSM6DS3TR_C_EACH_SH_CYCLE:
-          *val = LSM6DS3TR_C_EACH_SH_CYCLE;
-          break;
-
-        case LSM6DS3TR_C_ONLY_FIRST_CYCLE:
-          *val = LSM6DS3TR_C_ONLY_FIRST_CYCLE;
-          break;
-
-        default:
-          *val = LSM6DS3TR_C_SH_WR_MODE_ND;
-          break;
-      }
-
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Decimation of read operation on Slave 1 starting from the
-  *         sensor hub trigger.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of slave1_rate in reg SLAVE1_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slave_1_dec_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave1_rate_t val)
-{
-  lsm6ds3tr_c_slave1_config_t slave1_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG,
-                               (uint8_t *)&slave1_config, 1);
-
-    if (ret == 0)
-    {
-      slave1_config.slave1_rate = (uint8_t) val;
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG,
-                                  (uint8_t *)&slave1_config, 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Decimation of read operation on Slave 1 starting from the
-  *         sensor hub trigger.[get]
-  *
-  * @param  ctx    Read / write interface definitions reg SLAVE1_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slave_1_dec_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave1_rate_t *val)
-{
-  lsm6ds3tr_c_slave1_config_t slave1_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG,
-                               (uint8_t *)&slave1_config, 1);
-
-    if (ret == 0)
-    {
-      switch (slave1_config.slave1_rate)
-      {
-        case LSM6DS3TR_C_SL1_NO_DEC:
-          *val = LSM6DS3TR_C_SL1_NO_DEC;
-          break;
-
-        case LSM6DS3TR_C_SL1_DEC_2:
-          *val = LSM6DS3TR_C_SL1_DEC_2;
-          break;
-
-        case LSM6DS3TR_C_SL1_DEC_4:
-          *val = LSM6DS3TR_C_SL1_DEC_4;
-          break;
-
-        case LSM6DS3TR_C_SL1_DEC_8:
-          *val = LSM6DS3TR_C_SL1_DEC_8;
-          break;
-
-        default:
-          *val = LSM6DS3TR_C_SL1_DEC_ND;
-          break;
-      }
-
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Decimation of read operation on Slave 2 starting from the
-  *         sensor hub trigger.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of slave2_rate in reg SLAVE2_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slave_2_dec_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave2_rate_t val)
-{
-  lsm6ds3tr_c_slave2_config_t slave2_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE2_CONFIG,
-                               (uint8_t *)&slave2_config, 1);
-
-    if (ret == 0)
-    {
-      slave2_config.slave2_rate = (uint8_t) val;
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE2_CONFIG,
-                                  (uint8_t *)&slave2_config, 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Decimation of read operation on Slave 2 starting from the
-  *         sensor hub trigger.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of slave2_rate in reg SLAVE2_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slave_2_dec_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave2_rate_t *val)
-{
-  lsm6ds3tr_c_slave2_config_t slave2_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE2_CONFIG,
-                               (uint8_t *)&slave2_config, 1);
-
-    if (ret == 0)
-    {
-      switch (slave2_config.slave2_rate)
-      {
-        case LSM6DS3TR_C_SL2_NO_DEC:
-          *val = LSM6DS3TR_C_SL2_NO_DEC;
-          break;
-
-        case LSM6DS3TR_C_SL2_DEC_2:
-          *val = LSM6DS3TR_C_SL2_DEC_2;
-          break;
-
-        case LSM6DS3TR_C_SL2_DEC_4:
-          *val = LSM6DS3TR_C_SL2_DEC_4;
-          break;
-
-        case LSM6DS3TR_C_SL2_DEC_8:
-          *val = LSM6DS3TR_C_SL2_DEC_8;
-          break;
-
-        default:
-          *val = LSM6DS3TR_C_SL2_DEC_ND;
-          break;
-      }
-
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Decimation of read operation on Slave 3 starting from the
-  *         sensor hub trigger.[set]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Change the values of slave3_rate in reg SLAVE3_CONFIG
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slave_3_dec_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave3_rate_t val)
-{
-  lsm6ds3tr_c_slave3_config_t slave3_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE3_CONFIG,
-                               (uint8_t *)&slave3_config, 1);
-    slave3_config.slave3_rate = (uint8_t)val;
-
-    if (ret == 0)
-    {
-      ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE3_CONFIG,
-                                  (uint8_t *)&slave3_config, 1);
-
-      if (ret == 0)
-      {
-        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-      }
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @brief  Decimation of read operation on Slave 3 starting from the
-  *         sensor hub trigger.[get]
-  *
-  * @param  ctx    Read / write interface definitions
-  * @param  val    Get the values of slave3_rate in reg SLAVE3_CONFIG.
-  * @retval        Interface status (MANDATORY: return 0 -> no Error).
-  *
-  */
-int32_t lsm6ds3tr_c_sh_slave_3_dec_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave3_rate_t *val)
-{
-  lsm6ds3tr_c_slave3_config_t slave3_config;
-  int32_t ret;
-
-  ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
-
-  if (ret == 0)
-  {
-    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE3_CONFIG,
-                               (uint8_t *)&slave3_config, 1);
-
-    if (ret == 0)
-    {
-      switch (slave3_config.slave3_rate)
-      {
-        case LSM6DS3TR_C_SL3_NO_DEC:
-          *val = LSM6DS3TR_C_SL3_NO_DEC;
-          break;
-
-        case LSM6DS3TR_C_SL3_DEC_2:
-          *val = LSM6DS3TR_C_SL3_DEC_2;
-          break;
-
-        case LSM6DS3TR_C_SL3_DEC_4:
-          *val = LSM6DS3TR_C_SL3_DEC_4;
-          break;
-
-        case LSM6DS3TR_C_SL3_DEC_8:
-          *val = LSM6DS3TR_C_SL3_DEC_8;
-          break;
-
-        default:
-          *val = LSM6DS3TR_C_SL3_DEC_ND;
-          break;
-      }
-
-      ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
-    }
-  }
-
-  return ret;
-}
-
-/**
-  * @}
-  *
-  */
-
-/**
-  * @}
-  *
-  */
-
-/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/

+ 0 - 2798
tracking/imu/lsm6ds3tr-c_reg.h

@@ -1,2798 +0,0 @@
-/**
-  ******************************************************************************
-  * @file    lsm6ds3tr_c_reg.h
-  * @author  Sensors Software Solution Team
-  * @brief   This file contains all the functions prototypes for the
-  *          lsm6ds3tr_c_reg.c driver.
-  ******************************************************************************
-  * @attention
-  *
-  * <h2><center>&copy; Copyright (c) 2021 STMicroelectronics.
-  * All rights reserved.</center></h2>
-  *
-  * This software component is licensed by ST under BSD 3-Clause license,
-  * the "License"; You may not use this file except in compliance with the
-  * License. You may obtain a copy of the License at:
-  *                        opensource.org/licenses/BSD-3-Clause
-  *
-  ******************************************************************************
-  */
-
-/* Define to prevent recursive inclusion -------------------------------------*/
-#ifndef LSM6DS3TR_C_DRIVER_H
-#define LSM6DS3TR_C_DRIVER_H
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/* Includes ------------------------------------------------------------------*/
-#include <stdint.h>
-#include <stddef.h>
-#include <math.h>
-
-/** @addtogroup LSM6DS3TR_C
-  * @{
-  *
-  */
-
-/** @defgroup  Endianness definitions
-  * @{
-  *
-  */
-
-#ifndef DRV_BYTE_ORDER
-#ifndef __BYTE_ORDER__
-
-#define DRV_LITTLE_ENDIAN 1234
-#define DRV_BIG_ENDIAN    4321
-
-/** if _BYTE_ORDER is not defined, choose the endianness of your architecture
-  * by uncommenting the define which fits your platform endianness
-  */
-//#define DRV_BYTE_ORDER    DRV_BIG_ENDIAN
-#define DRV_BYTE_ORDER    DRV_LITTLE_ENDIAN
-
-#else /* defined __BYTE_ORDER__ */
-
-#define DRV_LITTLE_ENDIAN  __ORDER_LITTLE_ENDIAN__
-#define DRV_BIG_ENDIAN     __ORDER_BIG_ENDIAN__
-#define DRV_BYTE_ORDER     __BYTE_ORDER__
-
-#endif /* __BYTE_ORDER__*/
-#endif /* DRV_BYTE_ORDER */
-
-/**
-  * @}
-  *
-  */
-
-/** @defgroup STMicroelectronics sensors common types
-  * @{
-  *
-  */
-
-#ifndef MEMS_SHARED_TYPES
-#define MEMS_SHARED_TYPES
-
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0       : 1;
-  uint8_t bit1       : 1;
-  uint8_t bit2       : 1;
-  uint8_t bit3       : 1;
-  uint8_t bit4       : 1;
-  uint8_t bit5       : 1;
-  uint8_t bit6       : 1;
-  uint8_t bit7       : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7       : 1;
-  uint8_t bit6       : 1;
-  uint8_t bit5       : 1;
-  uint8_t bit4       : 1;
-  uint8_t bit3       : 1;
-  uint8_t bit2       : 1;
-  uint8_t bit1       : 1;
-  uint8_t bit0       : 1;
-#endif /* DRV_BYTE_ORDER */
-} bitwise_t;
-
-#define PROPERTY_DISABLE                (0U)
-#define PROPERTY_ENABLE                 (1U)
-
-/** @addtogroup  Interfaces_Functions
-  * @brief       This section provide a set of functions used to read and
-  *              write a generic register of the device.
-  *              MANDATORY: return 0 -> no Error.
-  * @{
-  *
-  */
-
-typedef int32_t (*stmdev_write_ptr)(void *, uint8_t, const uint8_t *, uint16_t);
-typedef int32_t (*stmdev_read_ptr)(void *, uint8_t, uint8_t *, uint16_t);
-typedef void (*stmdev_mdelay_ptr)(uint32_t millisec);
-
-typedef struct
-{
-  /** Component mandatory fields **/
-  stmdev_write_ptr  write_reg;
-  stmdev_read_ptr   read_reg;
-  /** Component optional fields **/
-  stmdev_mdelay_ptr   mdelay;
-  /** Customizable optional pointer **/
-  void *handle;
-} stmdev_ctx_t;
-
-/**
-  * @}
-  *
-  */
-
-#endif /* MEMS_SHARED_TYPES */
-
-#ifndef MEMS_UCF_SHARED_TYPES
-#define MEMS_UCF_SHARED_TYPES
-
-/** @defgroup    Generic address-data structure definition
-  * @brief       This structure is useful to load a predefined configuration
-  *              of a sensor.
-  *              You can create a sensor configuration by your own or using
-  *              Unico / Unicleo tools available on STMicroelectronics
-  *              web site.
-  *
-  * @{
-  *
-  */
-
-typedef struct
-{
-  uint8_t address;
-  uint8_t data;
-} ucf_line_t;
-
-/**
-  * @}
-  *
-  */
-
-#endif /* MEMS_UCF_SHARED_TYPES */
-
-/**
-  * @}
-  *
-  */
-
-/** @defgroup LSM6DS3TR_C_Infos
-  * @{
-  *
-  */
-
-/** I2C Device Address 8 bit format  if SA0=0 -> D5 if SA0=1 -> D7 **/
-#define LSM6DS3TR_C_I2C_ADD_L     0xD5U
-#define LSM6DS3TR_C_I2C_ADD_H     0xD7U
-
-/** Device Identification (Who am I) **/
-#define LSM6DS3TR_C_ID            0x6AU
-
-/**
-  * @}
-  *
-  */
-
-#define LSM6DS3TR_C_FUNC_CFG_ACCESS              0x01U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t not_used_01              : 5;
-uint8_t func_cfg_en              :
-  3;  /* func_cfg_en + func_cfg_en_b */
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-uint8_t func_cfg_en              :
-  3;  /* func_cfg_en + func_cfg_en_b */
-  uint8_t not_used_01              : 5;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_func_cfg_access_t;
-
-#define LSM6DS3TR_C_SENSOR_SYNC_TIME_FRAME       0x04U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t tph                      : 4;
-  uint8_t not_used_01              : 4;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t not_used_01              : 4;
-  uint8_t tph                      : 4;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensor_sync_time_frame_t;
-
-#define LSM6DS3TR_C_SENSOR_SYNC_RES_RATIO        0x05U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t rr                       : 2;
-  uint8_t not_used_01              : 6;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t not_used_01              : 6;
-  uint8_t rr                       : 2;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensor_sync_res_ratio_t;
-
-#define LSM6DS3TR_C_FIFO_CTRL1                   0x06U
-typedef struct
-{
-  uint8_t fth                      : 8;  /* + FIFO_CTRL2(fth) */
-} lsm6ds3tr_c_fifo_ctrl1_t;
-
-#define LSM6DS3TR_C_FIFO_CTRL2                   0x07U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t fth                      : 3;  /* + FIFO_CTRL1(fth) */
-  uint8_t fifo_temp_en             : 1;
-  uint8_t not_used_01              : 2;
-  uint8_t timer_pedo_fifo_drdy     : 1;
-  uint8_t timer_pedo_fifo_en       : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t timer_pedo_fifo_en       : 1;
-  uint8_t timer_pedo_fifo_drdy     : 1;
-  uint8_t not_used_01              : 2;
-  uint8_t fifo_temp_en             : 1;
-  uint8_t fth                      : 3;  /* + FIFO_CTRL1(fth) */
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_fifo_ctrl2_t;
-
-#define LSM6DS3TR_C_FIFO_CTRL3                   0x08U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t dec_fifo_xl              : 3;
-  uint8_t dec_fifo_gyro            : 3;
-  uint8_t not_used_01              : 2;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t not_used_01              : 2;
-  uint8_t dec_fifo_gyro            : 3;
-  uint8_t dec_fifo_xl              : 3;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_fifo_ctrl3_t;
-
-#define LSM6DS3TR_C_FIFO_CTRL4                   0x09U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t dec_ds3_fifo             : 3;
-  uint8_t dec_ds4_fifo             : 3;
-  uint8_t only_high_data           : 1;
-  uint8_t stop_on_fth              : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t stop_on_fth              : 1;
-  uint8_t only_high_data           : 1;
-  uint8_t dec_ds4_fifo             : 3;
-  uint8_t dec_ds3_fifo             : 3;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_fifo_ctrl4_t;
-
-#define LSM6DS3TR_C_FIFO_CTRL5                   0x0AU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t fifo_mode                : 3;
-  uint8_t odr_fifo                 : 4;
-  uint8_t not_used_01              : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t not_used_01              : 1;
-  uint8_t odr_fifo                 : 4;
-  uint8_t fifo_mode                : 3;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_fifo_ctrl5_t;
-
-#define LSM6DS3TR_C_DRDY_PULSE_CFG_G             0x0BU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t int2_wrist_tilt          : 1;
-  uint8_t not_used_01              : 6;
-  uint8_t drdy_pulsed              : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t drdy_pulsed              : 1;
-  uint8_t not_used_01              : 6;
-  uint8_t int2_wrist_tilt          : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_drdy_pulse_cfg_g_t;
-
-#define LSM6DS3TR_C_INT1_CTRL                    0x0DU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t int1_drdy_xl             : 1;
-  uint8_t int1_drdy_g              : 1;
-  uint8_t int1_boot                : 1;
-  uint8_t int1_fth                 : 1;
-  uint8_t int1_fifo_ovr            : 1;
-  uint8_t int1_full_flag           : 1;
-  uint8_t int1_sign_mot            : 1;
-  uint8_t int1_step_detector       : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t int1_step_detector       : 1;
-  uint8_t int1_sign_mot            : 1;
-  uint8_t int1_full_flag           : 1;
-  uint8_t int1_fifo_ovr            : 1;
-  uint8_t int1_fth                 : 1;
-  uint8_t int1_boot                : 1;
-  uint8_t int1_drdy_g              : 1;
-  uint8_t int1_drdy_xl             : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_int1_ctrl_t;
-
-#define LSM6DS3TR_C_INT2_CTRL                    0x0EU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t int2_drdy_xl             : 1;
-  uint8_t int2_drdy_g              : 1;
-  uint8_t int2_drdy_temp           : 1;
-  uint8_t int2_fth                 : 1;
-  uint8_t int2_fifo_ovr            : 1;
-  uint8_t int2_full_flag           : 1;
-  uint8_t int2_step_count_ov       : 1;
-  uint8_t int2_step_delta          : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t int2_step_delta          : 1;
-  uint8_t int2_step_count_ov       : 1;
-  uint8_t int2_full_flag           : 1;
-  uint8_t int2_fifo_ovr            : 1;
-  uint8_t int2_fth                 : 1;
-  uint8_t int2_drdy_temp           : 1;
-  uint8_t int2_drdy_g              : 1;
-  uint8_t int2_drdy_xl             : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_int2_ctrl_t;
-
-#define LSM6DS3TR_C_WHO_AM_I                     0x0FU
-#define LSM6DS3TR_C_CTRL1_XL                     0x10U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bw0_xl                   : 1;
-  uint8_t lpf1_bw_sel              : 1;
-  uint8_t fs_xl                    : 2;
-  uint8_t odr_xl                   : 4;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t odr_xl                   : 4;
-  uint8_t fs_xl                    : 2;
-  uint8_t lpf1_bw_sel              : 1;
-  uint8_t bw0_xl                   : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_ctrl1_xl_t;
-
-#define LSM6DS3TR_C_CTRL2_G                      0x11U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t not_used_01              : 1;
-  uint8_t fs_g                     : 3;  /* fs_g + fs_125 */
-  uint8_t odr_g                    : 4;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t odr_g                    : 4;
-  uint8_t fs_g                     : 3;  /* fs_g + fs_125 */
-  uint8_t not_used_01              : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_ctrl2_g_t;
-
-#define LSM6DS3TR_C_CTRL3_C                      0x12U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t sw_reset                 : 1;
-  uint8_t ble                      : 1;
-  uint8_t if_inc                   : 1;
-  uint8_t sim                      : 1;
-  uint8_t pp_od                    : 1;
-  uint8_t h_lactive                : 1;
-  uint8_t bdu                      : 1;
-  uint8_t boot                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t boot                     : 1;
-  uint8_t bdu                      : 1;
-  uint8_t h_lactive                : 1;
-  uint8_t pp_od                    : 1;
-  uint8_t sim                      : 1;
-  uint8_t if_inc                   : 1;
-  uint8_t ble                      : 1;
-  uint8_t sw_reset                 : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_ctrl3_c_t;
-
-#define LSM6DS3TR_C_CTRL4_C                      0x13U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t not_used_01              : 1;
-  uint8_t lpf1_sel_g               : 1;
-  uint8_t i2c_disable              : 1;
-  uint8_t drdy_mask                : 1;
-  uint8_t den_drdy_int1            : 1;
-  uint8_t int2_on_int1             : 1;
-  uint8_t sleep                    : 1;
-  uint8_t den_xl_en                : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t den_xl_en                : 1;
-  uint8_t sleep                    : 1;
-  uint8_t int2_on_int1             : 1;
-  uint8_t den_drdy_int1            : 1;
-  uint8_t drdy_mask                : 1;
-  uint8_t i2c_disable              : 1;
-  uint8_t lpf1_sel_g               : 1;
-  uint8_t not_used_01              : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_ctrl4_c_t;
-
-#define LSM6DS3TR_C_CTRL5_C                      0x14U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t st_xl                    : 2;
-  uint8_t st_g                     : 2;
-  uint8_t den_lh                   : 1;
-  uint8_t rounding                 : 3;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t rounding                 : 3;
-  uint8_t den_lh                   : 1;
-  uint8_t st_g                     : 2;
-  uint8_t st_xl                    : 2;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_ctrl5_c_t;
-
-#define LSM6DS3TR_C_CTRL6_C                      0x15U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t ftype                    : 2;
-  uint8_t not_used_01              : 1;
-  uint8_t usr_off_w                : 1;
-  uint8_t xl_hm_mode               : 1;
-uint8_t den_mode                 :
-  3;  /* trig_en + lvl_en + lvl2_en */
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-uint8_t den_mode                 :
-  3;  /* trig_en + lvl_en + lvl2_en */
-  uint8_t xl_hm_mode               : 1;
-  uint8_t usr_off_w                : 1;
-  uint8_t not_used_01              : 1;
-  uint8_t ftype                    : 2;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_ctrl6_c_t;
-
-#define LSM6DS3TR_C_CTRL7_G                      0x16U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t not_used_01              : 2;
-  uint8_t rounding_status          : 1;
-  uint8_t not_used_02              : 1;
-  uint8_t hpm_g                    : 2;
-  uint8_t hp_en_g                  : 1;
-  uint8_t g_hm_mode                : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t g_hm_mode                : 1;
-  uint8_t hp_en_g                  : 1;
-  uint8_t hpm_g                    : 2;
-  uint8_t not_used_02              : 1;
-  uint8_t rounding_status          : 1;
-  uint8_t not_used_01              : 2;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_ctrl7_g_t;
-
-#define LSM6DS3TR_C_CTRL8_XL                     0x17U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t low_pass_on_6d           : 1;
-  uint8_t not_used_01              : 1;
-  uint8_t hp_slope_xl_en           : 1;
-  uint8_t input_composite          : 1;
-  uint8_t hp_ref_mode              : 1;
-  uint8_t hpcf_xl                  : 2;
-  uint8_t lpf2_xl_en               : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t lpf2_xl_en               : 1;
-  uint8_t hpcf_xl                  : 2;
-  uint8_t hp_ref_mode              : 1;
-  uint8_t input_composite          : 1;
-  uint8_t hp_slope_xl_en           : 1;
-  uint8_t not_used_01              : 1;
-  uint8_t low_pass_on_6d           : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_ctrl8_xl_t;
-
-#define LSM6DS3TR_C_CTRL9_XL                     0x18U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t not_used_01              : 2;
-  uint8_t soft_en                  : 1;
-  uint8_t not_used_02              : 1;
-  uint8_t den_xl_g                 : 1;
-  uint8_t den_z                    : 1;
-  uint8_t den_y                    : 1;
-  uint8_t den_x                    : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t den_x                    : 1;
-  uint8_t den_y                    : 1;
-  uint8_t den_z                    : 1;
-  uint8_t den_xl_g                 : 1;
-  uint8_t not_used_02              : 1;
-  uint8_t soft_en                  : 1;
-  uint8_t not_used_01              : 2;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_ctrl9_xl_t;
-
-#define LSM6DS3TR_C_CTRL10_C                     0x19U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t sign_motion_en           : 1;
-  uint8_t pedo_rst_step            : 1;
-  uint8_t func_en                  : 1;
-  uint8_t tilt_en                  : 1;
-  uint8_t pedo_en                  : 1;
-  uint8_t timer_en                 : 1;
-  uint8_t not_used_01              : 1;
-  uint8_t wrist_tilt_en            : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t wrist_tilt_en            : 1;
-  uint8_t not_used_01              : 1;
-  uint8_t timer_en                 : 1;
-  uint8_t pedo_en                  : 1;
-  uint8_t tilt_en                  : 1;
-  uint8_t func_en                  : 1;
-  uint8_t pedo_rst_step            : 1;
-  uint8_t sign_motion_en           : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_ctrl10_c_t;
-
-#define LSM6DS3TR_C_MASTER_CONFIG                0x1AU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t master_on                : 1;
-  uint8_t iron_en                  : 1;
-  uint8_t pass_through_mode        : 1;
-  uint8_t pull_up_en               : 1;
-  uint8_t start_config             : 1;
-  uint8_t not_used_01              : 1;
-  uint8_t data_valid_sel_fifo      : 1;
-  uint8_t drdy_on_int1             : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t drdy_on_int1             : 1;
-  uint8_t data_valid_sel_fifo      : 1;
-  uint8_t not_used_01              : 1;
-  uint8_t start_config             : 1;
-  uint8_t pull_up_en               : 1;
-  uint8_t pass_through_mode        : 1;
-  uint8_t iron_en                  : 1;
-  uint8_t master_on                : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_master_config_t;
-
-#define LSM6DS3TR_C_WAKE_UP_SRC                  0x1BU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t z_wu                     : 1;
-  uint8_t y_wu                     : 1;
-  uint8_t x_wu                     : 1;
-  uint8_t wu_ia                    : 1;
-  uint8_t sleep_state_ia           : 1;
-  uint8_t ff_ia                    : 1;
-  uint8_t not_used_01              : 2;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t not_used_01              : 2;
-  uint8_t ff_ia                    : 1;
-  uint8_t sleep_state_ia           : 1;
-  uint8_t wu_ia                    : 1;
-  uint8_t x_wu                     : 1;
-  uint8_t y_wu                     : 1;
-  uint8_t z_wu                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_wake_up_src_t;
-
-#define LSM6DS3TR_C_TAP_SRC                      0x1CU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t z_tap                    : 1;
-  uint8_t y_tap                    : 1;
-  uint8_t x_tap                    : 1;
-  uint8_t tap_sign                 : 1;
-  uint8_t double_tap               : 1;
-  uint8_t single_tap               : 1;
-  uint8_t tap_ia                   : 1;
-  uint8_t not_used_01              : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t not_used_01              : 1;
-  uint8_t tap_ia                   : 1;
-  uint8_t single_tap               : 1;
-  uint8_t double_tap               : 1;
-  uint8_t tap_sign                 : 1;
-  uint8_t x_tap                    : 1;
-  uint8_t y_tap                    : 1;
-  uint8_t z_tap                    : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_tap_src_t;
-
-#define LSM6DS3TR_C_D6D_SRC                      0x1DU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t xl                       : 1;
-  uint8_t xh                       : 1;
-  uint8_t yl                       : 1;
-  uint8_t yh                       : 1;
-  uint8_t zl                       : 1;
-  uint8_t zh                       : 1;
-  uint8_t d6d_ia                   : 1;
-  uint8_t den_drdy                 : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t den_drdy                 : 1;
-  uint8_t d6d_ia                   : 1;
-  uint8_t zh                       : 1;
-  uint8_t zl                       : 1;
-  uint8_t yh                       : 1;
-  uint8_t yl                       : 1;
-  uint8_t xh                       : 1;
-  uint8_t xl                       : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_d6d_src_t;
-
-#define LSM6DS3TR_C_STATUS_REG                   0x1EU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t xlda                     : 1;
-  uint8_t gda                      : 1;
-  uint8_t tda                      : 1;
-  uint8_t not_used_01              : 5;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t not_used_01              : 5;
-  uint8_t tda                      : 1;
-  uint8_t gda                      : 1;
-  uint8_t xlda                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_status_reg_t;
-
-#define LSM6DS3TR_C_OUT_TEMP_L                   0x20U
-#define LSM6DS3TR_C_OUT_TEMP_H                   0x21U
-#define LSM6DS3TR_C_OUTX_L_G                     0x22U
-#define LSM6DS3TR_C_OUTX_H_G                     0x23U
-#define LSM6DS3TR_C_OUTY_L_G                     0x24U
-#define LSM6DS3TR_C_OUTY_H_G                     0x25U
-#define LSM6DS3TR_C_OUTZ_L_G                     0x26U
-#define LSM6DS3TR_C_OUTZ_H_G                     0x27U
-#define LSM6DS3TR_C_OUTX_L_XL                    0x28U
-#define LSM6DS3TR_C_OUTX_H_XL                    0x29U
-#define LSM6DS3TR_C_OUTY_L_XL                    0x2AU
-#define LSM6DS3TR_C_OUTY_H_XL                    0x2BU
-#define LSM6DS3TR_C_OUTZ_L_XL                    0x2CU
-#define LSM6DS3TR_C_OUTZ_H_XL                    0x2DU
-#define LSM6DS3TR_C_SENSORHUB1_REG               0x2EU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub1_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB2_REG               0x2FU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub2_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB3_REG               0x30U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub3_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB4_REG               0x31U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub4_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB5_REG               0x32U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub5_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB6_REG               0x33U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub6_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB7_REG               0x34U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub7_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB8_REG               0x35U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub8_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB9_REG               0x36U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub9_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB10_REG              0x37U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub10_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB11_REG              0x38U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub11_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB12_REG              0x39U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub12_reg_t;
-
-#define LSM6DS3TR_C_FIFO_STATUS1                 0x3AU
-typedef struct
-{
-  uint8_t diff_fifo                : 8;  /* + FIFO_STATUS2(diff_fifo) */
-} lsm6ds3tr_c_fifo_status1_t;
-
-#define LSM6DS3TR_C_FIFO_STATUS2                 0x3BU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t diff_fifo                : 3;  /* + FIFO_STATUS1(diff_fifo) */
-  uint8_t not_used_01              : 1;
-  uint8_t fifo_empty               : 1;
-  uint8_t fifo_full_smart          : 1;
-  uint8_t over_run                 : 1;
-  uint8_t waterm                   : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t waterm                   : 1;
-  uint8_t over_run                 : 1;
-  uint8_t fifo_full_smart          : 1;
-  uint8_t fifo_empty               : 1;
-  uint8_t not_used_01              : 1;
-  uint8_t diff_fifo                : 3;  /* + FIFO_STATUS1(diff_fifo) */
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_fifo_status2_t;
-
-#define LSM6DS3TR_C_FIFO_STATUS3                 0x3CU
-typedef struct
-{
-uint8_t fifo_pattern             :
-  8;  /* + FIFO_STATUS4(fifo_pattern) */
-} lsm6ds3tr_c_fifo_status3_t;
-
-#define LSM6DS3TR_C_FIFO_STATUS4                 0x3DU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-uint8_t fifo_pattern             :
-  2;  /* + FIFO_STATUS3(fifo_pattern) */
-  uint8_t not_used_01              : 6;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t not_used_01              : 6;
-uint8_t fifo_pattern             :
-  2;  /* + FIFO_STATUS3(fifo_pattern) */
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_fifo_status4_t;
-
-#define LSM6DS3TR_C_FIFO_DATA_OUT_L              0x3EU
-#define LSM6DS3TR_C_FIFO_DATA_OUT_H              0x3FU
-#define LSM6DS3TR_C_TIMESTAMP0_REG               0x40U
-#define LSM6DS3TR_C_TIMESTAMP1_REG               0x41U
-#define LSM6DS3TR_C_TIMESTAMP2_REG               0x42U
-#define LSM6DS3TR_C_STEP_TIMESTAMP_L             0x49U
-#define LSM6DS3TR_C_STEP_TIMESTAMP_H             0x4AU
-#define LSM6DS3TR_C_STEP_COUNTER_L               0x4BU
-#define LSM6DS3TR_C_STEP_COUNTER_H               0x4CU
-
-#define LSM6DS3TR_C_SENSORHUB13_REG              0x4DU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub13_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB14_REG              0x4EU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub14_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB15_REG              0x4FU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub15_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB16_REG              0x50U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub16_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB17_REG              0x51U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub17_reg_t;
-
-#define LSM6DS3TR_C_SENSORHUB18_REG              0x52U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t bit0                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit7                     : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t bit7                     : 1;
-  uint8_t bit6                     : 1;
-  uint8_t bit5                     : 1;
-  uint8_t bit4                     : 1;
-  uint8_t bit3                     : 1;
-  uint8_t bit2                     : 1;
-  uint8_t bit1                     : 1;
-  uint8_t bit0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_sensorhub18_reg_t;
-
-#define LSM6DS3TR_C_FUNC_SRC1                    0x53U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t sensorhub_end_op         : 1;
-  uint8_t si_end_op                : 1;
-  uint8_t hi_fail                  : 1;
-  uint8_t step_overflow            : 1;
-  uint8_t step_detected            : 1;
-  uint8_t tilt_ia                  : 1;
-  uint8_t sign_motion_ia           : 1;
-  uint8_t step_count_delta_ia      : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t step_count_delta_ia      : 1;
-  uint8_t sign_motion_ia           : 1;
-  uint8_t tilt_ia                  : 1;
-  uint8_t step_detected            : 1;
-  uint8_t step_overflow            : 1;
-  uint8_t hi_fail                  : 1;
-  uint8_t si_end_op                : 1;
-  uint8_t sensorhub_end_op         : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_func_src1_t;
-
-#define LSM6DS3TR_C_FUNC_SRC2                    0x54U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t wrist_tilt_ia            : 1;
-  uint8_t not_used_01              : 2;
-  uint8_t slave0_nack              : 1;
-  uint8_t slave1_nack              : 1;
-  uint8_t slave2_nack              : 1;
-  uint8_t slave3_nack              : 1;
-  uint8_t not_used_02              : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t not_used_02              : 1;
-  uint8_t slave3_nack              : 1;
-  uint8_t slave2_nack              : 1;
-  uint8_t slave1_nack              : 1;
-  uint8_t slave0_nack              : 1;
-  uint8_t not_used_01              : 2;
-  uint8_t wrist_tilt_ia            : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_func_src2_t;
-
-#define LSM6DS3TR_C_WRIST_TILT_IA                0x55U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t not_used_01              : 2;
-  uint8_t wrist_tilt_ia_zneg       : 1;
-  uint8_t wrist_tilt_ia_zpos       : 1;
-  uint8_t wrist_tilt_ia_yneg       : 1;
-  uint8_t wrist_tilt_ia_ypos       : 1;
-  uint8_t wrist_tilt_ia_xneg       : 1;
-  uint8_t wrist_tilt_ia_xpos       : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t wrist_tilt_ia_xpos       : 1;
-  uint8_t wrist_tilt_ia_xneg       : 1;
-  uint8_t wrist_tilt_ia_ypos       : 1;
-  uint8_t wrist_tilt_ia_yneg       : 1;
-  uint8_t wrist_tilt_ia_zpos       : 1;
-  uint8_t wrist_tilt_ia_zneg       : 1;
-  uint8_t not_used_01              : 2;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_wrist_tilt_ia_t;
-
-#define LSM6DS3TR_C_TAP_CFG                      0x58U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t lir                      : 1;
-  uint8_t tap_z_en                 : 1;
-  uint8_t tap_y_en                 : 1;
-  uint8_t tap_x_en                 : 1;
-  uint8_t slope_fds                : 1;
-  uint8_t inact_en                 : 2;
-  uint8_t interrupts_enable        : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t interrupts_enable        : 1;
-  uint8_t inact_en                 : 2;
-  uint8_t slope_fds                : 1;
-  uint8_t tap_x_en                 : 1;
-  uint8_t tap_y_en                 : 1;
-  uint8_t tap_z_en                 : 1;
-  uint8_t lir                      : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_tap_cfg_t;
-
-#define LSM6DS3TR_C_TAP_THS_6D                   0x59U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t tap_ths                  : 5;
-  uint8_t sixd_ths                 : 2;
-  uint8_t d4d_en                   : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t d4d_en                   : 1;
-  uint8_t sixd_ths                 : 2;
-  uint8_t tap_ths                  : 5;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_tap_ths_6d_t;
-
-#define LSM6DS3TR_C_INT_DUR2                     0x5AU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t shock                    : 2;
-  uint8_t quiet                    : 2;
-  uint8_t dur                      : 4;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t dur                      : 4;
-  uint8_t quiet                    : 2;
-  uint8_t shock                    : 2;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_int_dur2_t;
-
-#define LSM6DS3TR_C_WAKE_UP_THS                  0x5BU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t wk_ths                   : 6;
-  uint8_t not_used_01              : 1;
-  uint8_t single_double_tap        : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t single_double_tap        : 1;
-  uint8_t not_used_01              : 1;
-  uint8_t wk_ths                   : 6;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_wake_up_ths_t;
-
-#define LSM6DS3TR_C_WAKE_UP_DUR                  0x5CU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t sleep_dur                : 4;
-  uint8_t timer_hr                 : 1;
-  uint8_t wake_dur                 : 2;
-  uint8_t ff_dur                   : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t ff_dur                   : 1;
-  uint8_t wake_dur                 : 2;
-  uint8_t timer_hr                 : 1;
-  uint8_t sleep_dur                : 4;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_wake_up_dur_t;
-
-#define LSM6DS3TR_C_FREE_FALL                    0x5DU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t ff_ths                   : 3;
-  uint8_t ff_dur                   : 5;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t ff_dur                   : 5;
-  uint8_t ff_ths                   : 3;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_free_fall_t;
-
-#define LSM6DS3TR_C_MD1_CFG                      0x5EU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t int1_timer               : 1;
-  uint8_t int1_tilt                : 1;
-  uint8_t int1_6d                  : 1;
-  uint8_t int1_double_tap          : 1;
-  uint8_t int1_ff                  : 1;
-  uint8_t int1_wu                  : 1;
-  uint8_t int1_single_tap          : 1;
-  uint8_t int1_inact_state         : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t int1_inact_state         : 1;
-  uint8_t int1_single_tap          : 1;
-  uint8_t int1_wu                  : 1;
-  uint8_t int1_ff                  : 1;
-  uint8_t int1_double_tap          : 1;
-  uint8_t int1_6d                  : 1;
-  uint8_t int1_tilt                : 1;
-  uint8_t int1_timer               : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_md1_cfg_t;
-
-#define LSM6DS3TR_C_MD2_CFG                      0x5FU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t int2_iron                : 1;
-  uint8_t int2_tilt                : 1;
-  uint8_t int2_6d                  : 1;
-  uint8_t int2_double_tap          : 1;
-  uint8_t int2_ff                  : 1;
-  uint8_t int2_wu                  : 1;
-  uint8_t int2_single_tap          : 1;
-  uint8_t int2_inact_state         : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t int2_inact_state         : 1;
-  uint8_t int2_single_tap          : 1;
-  uint8_t int2_wu                  : 1;
-  uint8_t int2_ff                  : 1;
-  uint8_t int2_double_tap          : 1;
-  uint8_t int2_6d                  : 1;
-  uint8_t int2_tilt                : 1;
-  uint8_t int2_iron                : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_md2_cfg_t;
-
-#define LSM6DS3TR_C_MASTER_CMD_CODE              0x60U
-typedef struct
-{
-  uint8_t master_cmd_code          : 8;
-} lsm6ds3tr_c_master_cmd_code_t;
-
-#define LSM6DS3TR_C_SENS_SYNC_SPI_ERROR_CODE     0x61U
-typedef struct
-{
-  uint8_t error_code               : 8;
-} lsm6ds3tr_c_sens_sync_spi_error_code_t;
-
-#define LSM6DS3TR_C_OUT_MAG_RAW_X_L              0x66U
-#define LSM6DS3TR_C_OUT_MAG_RAW_X_H              0x67U
-#define LSM6DS3TR_C_OUT_MAG_RAW_Y_L              0x68U
-#define LSM6DS3TR_C_OUT_MAG_RAW_Y_H              0x69U
-#define LSM6DS3TR_C_OUT_MAG_RAW_Z_L              0x6AU
-#define LSM6DS3TR_C_OUT_MAG_RAW_Z_H              0x6BU
-#define LSM6DS3TR_C_X_OFS_USR                    0x73U
-#define LSM6DS3TR_C_Y_OFS_USR                    0x74U
-#define LSM6DS3TR_C_Z_OFS_USR                    0x75U
-#define LSM6DS3TR_C_SLV0_ADD                     0x02U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t rw_0                     : 1;
-  uint8_t slave0_add               : 7;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t slave0_add               : 7;
-  uint8_t rw_0                     : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_slv0_add_t;
-
-#define LSM6DS3TR_C_SLV0_SUBADD                  0x03U
-typedef struct
-{
-  uint8_t slave0_reg               : 8;
-} lsm6ds3tr_c_slv0_subadd_t;
-
-#define LSM6DS3TR_C_SLAVE0_CONFIG                0x04U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t slave0_numop             : 3;
-  uint8_t src_mode                 : 1;
-  uint8_t aux_sens_on              : 2;
-  uint8_t slave0_rate              : 2;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t slave0_rate              : 2;
-  uint8_t aux_sens_on              : 2;
-  uint8_t src_mode                 : 1;
-  uint8_t slave0_numop             : 3;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_slave0_config_t;
-
-#define LSM6DS3TR_C_SLV1_ADD                     0x05U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t r_1                      : 1;
-  uint8_t slave1_add               : 7;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t slave1_add               : 7;
-  uint8_t r_1                      : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_slv1_add_t;
-
-#define LSM6DS3TR_C_SLV1_SUBADD                  0x06U
-typedef struct
-{
-  uint8_t slave1_reg               : 8;
-} lsm6ds3tr_c_slv1_subadd_t;
-
-#define LSM6DS3TR_C_SLAVE1_CONFIG                0x07U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t slave1_numop             : 3;
-  uint8_t not_used_01              : 2;
-  uint8_t write_once               : 1;
-  uint8_t slave1_rate              : 2;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t slave1_rate              : 2;
-  uint8_t write_once               : 1;
-  uint8_t not_used_01              : 2;
-  uint8_t slave1_numop             : 3;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_slave1_config_t;
-
-#define LSM6DS3TR_C_SLV2_ADD                     0x08U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t r_2                      : 1;
-  uint8_t slave2_add               : 7;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t slave2_add               : 7;
-  uint8_t r_2                      : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_slv2_add_t;
-
-#define LSM6DS3TR_C_SLV2_SUBADD                  0x09U
-typedef struct
-{
-  uint8_t slave2_reg               : 8;
-} lsm6ds3tr_c_slv2_subadd_t;
-
-#define LSM6DS3TR_C_SLAVE2_CONFIG                0x0AU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t slave2_numop             : 3;
-  uint8_t not_used_01              : 3;
-  uint8_t slave2_rate              : 2;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t slave2_rate              : 2;
-  uint8_t not_used_01              : 3;
-  uint8_t slave2_numop             : 3;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_slave2_config_t;
-
-#define LSM6DS3TR_C_SLV3_ADD                     0x0BU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t r_3                      : 1;
-  uint8_t slave3_add               : 7;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t slave3_add               : 7;
-  uint8_t r_3                      : 1;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_slv3_add_t;
-
-#define LSM6DS3TR_C_SLV3_SUBADD                  0x0CU
-typedef struct
-{
-  uint8_t slave3_reg               : 8;
-} lsm6ds3tr_c_slv3_subadd_t;
-
-#define LSM6DS3TR_C_SLAVE3_CONFIG                0x0DU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t slave3_numop             : 3;
-  uint8_t not_used_01              : 3;
-  uint8_t slave3_rate              : 2;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t slave3_rate              : 2;
-  uint8_t not_used_01              : 3;
-  uint8_t slave3_numop             : 3;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_slave3_config_t;
-
-#define LSM6DS3TR_C_DATAWRITE_SRC_MODE_SUB_SLV0  0x0EU
-typedef struct
-{
-  uint8_t slave_dataw              : 8;
-} lsm6ds3tr_c_datawrite_src_mode_sub_slv0_t;
-
-#define LSM6DS3TR_C_CONFIG_PEDO_THS_MIN          0x0FU
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t ths_min                  : 5;
-  uint8_t not_used_01              : 2;
-  uint8_t pedo_fs                  : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t pedo_fs                  : 1;
-  uint8_t not_used_01              : 2;
-  uint8_t ths_min                  : 5;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_config_pedo_ths_min_t;
-
-#define LSM6DS3TR_C_SM_THS                       0x13U
-#define LSM6DS3TR_C_PEDO_DEB_REG                 0x14U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t deb_step      : 3;
-  uint8_t deb_time      : 5;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t deb_time      : 5;
-  uint8_t deb_step      : 3;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_pedo_deb_reg_t;
-
-#define LSM6DS3TR_C_STEP_COUNT_DELTA             0x15U
-#define LSM6DS3TR_C_MAG_SI_XX                    0x24U
-#define LSM6DS3TR_C_MAG_SI_XY                    0x25U
-#define LSM6DS3TR_C_MAG_SI_XZ                    0x26U
-#define LSM6DS3TR_C_MAG_SI_YX                    0x27U
-#define LSM6DS3TR_C_MAG_SI_YY                    0x28U
-#define LSM6DS3TR_C_MAG_SI_YZ                    0x29U
-#define LSM6DS3TR_C_MAG_SI_ZX                    0x2AU
-#define LSM6DS3TR_C_MAG_SI_ZY                    0x2BU
-#define LSM6DS3TR_C_MAG_SI_ZZ                    0x2CU
-#define LSM6DS3TR_C_MAG_OFFX_L                   0x2DU
-#define LSM6DS3TR_C_MAG_OFFX_H                   0x2EU
-#define LSM6DS3TR_C_MAG_OFFY_L                   0x2FU
-#define LSM6DS3TR_C_MAG_OFFY_H                   0x30U
-#define LSM6DS3TR_C_MAG_OFFZ_L                   0x31U
-#define LSM6DS3TR_C_MAG_OFFZ_H                   0x32U
-#define LSM6DS3TR_C_A_WRIST_TILT_LAT             0x50U
-#define LSM6DS3TR_C_A_WRIST_TILT_THS             0x54U
-#define LSM6DS3TR_C_A_WRIST_TILT_MASK            0x59U
-typedef struct
-{
-#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
-  uint8_t not_used_01              : 2;
-  uint8_t  wrist_tilt_mask_zneg    : 1;
-  uint8_t  wrist_tilt_mask_zpos    : 1;
-  uint8_t  wrist_tilt_mask_yneg    : 1;
-  uint8_t  wrist_tilt_mask_ypos    : 1;
-  uint8_t  wrist_tilt_mask_xneg    : 1;
-  uint8_t  wrist_tilt_mask_xpos    : 1;
-#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
-  uint8_t  wrist_tilt_mask_xpos    : 1;
-  uint8_t  wrist_tilt_mask_xneg    : 1;
-  uint8_t  wrist_tilt_mask_ypos    : 1;
-  uint8_t  wrist_tilt_mask_yneg    : 1;
-  uint8_t  wrist_tilt_mask_zpos    : 1;
-  uint8_t  wrist_tilt_mask_zneg    : 1;
-  uint8_t not_used_01              : 2;
-#endif /* DRV_BYTE_ORDER */
-} lsm6ds3tr_c_a_wrist_tilt_mask_t;
-
-/**
-  * @defgroup LSM6DS3TR_C_Register_Union
-  * @brief    This union group all the registers having a bit-field
-  *           description.
-  *           This union is useful but it's not needed by the driver.
-  *
-  *           REMOVING this union you are compliant with:
-  *           MISRA-C 2012 [Rule 19.2] -> " Union are not allowed "
-  *
-  * @{
-  *
-  */
-typedef union
-{
-  lsm6ds3tr_c_func_cfg_access_t                  func_cfg_access;
-  lsm6ds3tr_c_sensor_sync_time_frame_t           sensor_sync_time_frame;
-  lsm6ds3tr_c_sensor_sync_res_ratio_t            sensor_sync_res_ratio;
-  lsm6ds3tr_c_fifo_ctrl1_t                       fifo_ctrl1;
-  lsm6ds3tr_c_fifo_ctrl2_t                       fifo_ctrl2;
-  lsm6ds3tr_c_fifo_ctrl3_t                       fifo_ctrl3;
-  lsm6ds3tr_c_fifo_ctrl4_t                       fifo_ctrl4;
-  lsm6ds3tr_c_fifo_ctrl5_t                       fifo_ctrl5;
-  lsm6ds3tr_c_drdy_pulse_cfg_g_t                 drdy_pulse_cfg_g;
-  lsm6ds3tr_c_int1_ctrl_t                        int1_ctrl;
-  lsm6ds3tr_c_int2_ctrl_t                        int2_ctrl;
-  lsm6ds3tr_c_ctrl1_xl_t                         ctrl1_xl;
-  lsm6ds3tr_c_ctrl2_g_t                          ctrl2_g;
-  lsm6ds3tr_c_ctrl3_c_t                          ctrl3_c;
-  lsm6ds3tr_c_ctrl4_c_t                          ctrl4_c;
-  lsm6ds3tr_c_ctrl5_c_t                          ctrl5_c;
-  lsm6ds3tr_c_ctrl6_c_t                          ctrl6_c;
-  lsm6ds3tr_c_ctrl7_g_t                          ctrl7_g;
-  lsm6ds3tr_c_ctrl8_xl_t                         ctrl8_xl;
-  lsm6ds3tr_c_ctrl9_xl_t                         ctrl9_xl;
-  lsm6ds3tr_c_ctrl10_c_t                         ctrl10_c;
-  lsm6ds3tr_c_master_config_t                    master_config;
-  lsm6ds3tr_c_wake_up_src_t                      wake_up_src;
-  lsm6ds3tr_c_tap_src_t                          tap_src;
-  lsm6ds3tr_c_d6d_src_t                          d6d_src;
-  lsm6ds3tr_c_status_reg_t                       status_reg;
-  lsm6ds3tr_c_sensorhub1_reg_t                   sensorhub1_reg;
-  lsm6ds3tr_c_sensorhub2_reg_t                   sensorhub2_reg;
-  lsm6ds3tr_c_sensorhub3_reg_t                   sensorhub3_reg;
-  lsm6ds3tr_c_sensorhub4_reg_t                   sensorhub4_reg;
-  lsm6ds3tr_c_sensorhub5_reg_t                   sensorhub5_reg;
-  lsm6ds3tr_c_sensorhub6_reg_t                   sensorhub6_reg;
-  lsm6ds3tr_c_sensorhub7_reg_t                   sensorhub7_reg;
-  lsm6ds3tr_c_sensorhub8_reg_t                   sensorhub8_reg;
-  lsm6ds3tr_c_sensorhub9_reg_t                   sensorhub9_reg;
-  lsm6ds3tr_c_sensorhub10_reg_t                  sensorhub10_reg;
-  lsm6ds3tr_c_sensorhub11_reg_t                  sensorhub11_reg;
-  lsm6ds3tr_c_sensorhub12_reg_t                  sensorhub12_reg;
-  lsm6ds3tr_c_fifo_status1_t                     fifo_status1;
-  lsm6ds3tr_c_fifo_status2_t                     fifo_status2;
-  lsm6ds3tr_c_fifo_status3_t                     fifo_status3;
-  lsm6ds3tr_c_fifo_status4_t                     fifo_status4;
-  lsm6ds3tr_c_sensorhub13_reg_t                  sensorhub13_reg;
-  lsm6ds3tr_c_sensorhub14_reg_t                  sensorhub14_reg;
-  lsm6ds3tr_c_sensorhub15_reg_t                  sensorhub15_reg;
-  lsm6ds3tr_c_sensorhub16_reg_t                  sensorhub16_reg;
-  lsm6ds3tr_c_sensorhub17_reg_t                  sensorhub17_reg;
-  lsm6ds3tr_c_sensorhub18_reg_t                  sensorhub18_reg;
-  lsm6ds3tr_c_func_src1_t                        func_src1;
-  lsm6ds3tr_c_func_src2_t                        func_src2;
-  lsm6ds3tr_c_wrist_tilt_ia_t                    wrist_tilt_ia;
-  lsm6ds3tr_c_tap_cfg_t                          tap_cfg;
-  lsm6ds3tr_c_tap_ths_6d_t                       tap_ths_6d;
-  lsm6ds3tr_c_int_dur2_t                         int_dur2;
-  lsm6ds3tr_c_wake_up_ths_t                      wake_up_ths;
-  lsm6ds3tr_c_wake_up_dur_t                      wake_up_dur;
-  lsm6ds3tr_c_free_fall_t                        free_fall;
-  lsm6ds3tr_c_md1_cfg_t                          md1_cfg;
-  lsm6ds3tr_c_md2_cfg_t                          md2_cfg;
-  lsm6ds3tr_c_master_cmd_code_t                  master_cmd_code;
-  lsm6ds3tr_c_sens_sync_spi_error_code_t
-  sens_sync_spi_error_code;
-  lsm6ds3tr_c_slv0_add_t                         slv0_add;
-  lsm6ds3tr_c_slv0_subadd_t                      slv0_subadd;
-  lsm6ds3tr_c_slave0_config_t                    slave0_config;
-  lsm6ds3tr_c_slv1_add_t                         slv1_add;
-  lsm6ds3tr_c_slv1_subadd_t                      slv1_subadd;
-  lsm6ds3tr_c_slave1_config_t                    slave1_config;
-  lsm6ds3tr_c_slv2_add_t                         slv2_add;
-  lsm6ds3tr_c_slv2_subadd_t                      slv2_subadd;
-  lsm6ds3tr_c_slave2_config_t                    slave2_config;
-  lsm6ds3tr_c_slv3_add_t                         slv3_add;
-  lsm6ds3tr_c_slv3_subadd_t                      slv3_subadd;
-  lsm6ds3tr_c_slave3_config_t                    slave3_config;
-  lsm6ds3tr_c_datawrite_src_mode_sub_slv0_t
-  datawrite_src_mode_sub_slv0;
-  lsm6ds3tr_c_config_pedo_ths_min_t              config_pedo_ths_min;
-  lsm6ds3tr_c_pedo_deb_reg_t                     pedo_deb_reg;
-  lsm6ds3tr_c_a_wrist_tilt_mask_t                a_wrist_tilt_mask;
-  bitwise_t                                  bitwise;
-  uint8_t                                    byte;
-} lsm6ds3tr_c_reg_t;
-
-/**
-  * @}
-  *
-  */
-
-int32_t lsm6ds3tr_c_read_reg(stmdev_ctx_t *ctx, uint8_t reg,
-                             uint8_t *data,
-                             uint16_t len);
-int32_t lsm6ds3tr_c_write_reg(stmdev_ctx_t *ctx, uint8_t reg,
-                              uint8_t *data,
-                              uint16_t len);
-
-float_t lsm6ds3tr_c_from_fs2g_to_mg(int16_t lsb);
-float_t lsm6ds3tr_c_from_fs4g_to_mg(int16_t lsb);
-float_t lsm6ds3tr_c_from_fs8g_to_mg(int16_t lsb);
-float_t lsm6ds3tr_c_from_fs16g_to_mg(int16_t lsb);
-
-float_t lsm6ds3tr_c_from_fs125dps_to_mdps(int16_t lsb);
-float_t lsm6ds3tr_c_from_fs250dps_to_mdps(int16_t lsb);
-float_t lsm6ds3tr_c_from_fs500dps_to_mdps(int16_t lsb);
-float_t lsm6ds3tr_c_from_fs1000dps_to_mdps(int16_t lsb);
-float_t lsm6ds3tr_c_from_fs2000dps_to_mdps(int16_t lsb);
-
-float_t lsm6ds3tr_c_from_lsb_to_celsius(int16_t lsb);
-
-typedef enum
-{
-  LSM6DS3TR_C_2g       = 0,
-  LSM6DS3TR_C_16g      = 1,
-  LSM6DS3TR_C_4g       = 2,
-  LSM6DS3TR_C_8g       = 3,
-  LSM6DS3TR_C_XL_FS_ND = 4,  /* ERROR CODE */
-} lsm6ds3tr_c_fs_xl_t;
-int32_t lsm6ds3tr_c_xl_full_scale_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_fs_xl_t val);
-int32_t lsm6ds3tr_c_xl_full_scale_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_fs_xl_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_XL_ODR_OFF      =  0,
-  LSM6DS3TR_C_XL_ODR_12Hz5    =  1,
-  LSM6DS3TR_C_XL_ODR_26Hz     =  2,
-  LSM6DS3TR_C_XL_ODR_52Hz     =  3,
-  LSM6DS3TR_C_XL_ODR_104Hz    =  4,
-  LSM6DS3TR_C_XL_ODR_208Hz    =  5,
-  LSM6DS3TR_C_XL_ODR_416Hz    =  6,
-  LSM6DS3TR_C_XL_ODR_833Hz    =  7,
-  LSM6DS3TR_C_XL_ODR_1k66Hz   =  8,
-  LSM6DS3TR_C_XL_ODR_3k33Hz   =  9,
-  LSM6DS3TR_C_XL_ODR_6k66Hz   = 10,
-  LSM6DS3TR_C_XL_ODR_1Hz6     = 11,
-  LSM6DS3TR_C_XL_ODR_ND       = 12,  /* ERROR CODE */
-} lsm6ds3tr_c_odr_xl_t;
-int32_t lsm6ds3tr_c_xl_data_rate_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_odr_xl_t val);
-int32_t lsm6ds3tr_c_xl_data_rate_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_odr_xl_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_250dps     = 0,
-  LSM6DS3TR_C_125dps     = 1,
-  LSM6DS3TR_C_500dps     = 2,
-  LSM6DS3TR_C_1000dps    = 4,
-  LSM6DS3TR_C_2000dps    = 6,
-  LSM6DS3TR_C_GY_FS_ND   = 7,    /* ERROR CODE */
-} lsm6ds3tr_c_fs_g_t;
-int32_t lsm6ds3tr_c_gy_full_scale_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_fs_g_t val);
-int32_t lsm6ds3tr_c_gy_full_scale_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_fs_g_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_GY_ODR_OFF    =  0,
-  LSM6DS3TR_C_GY_ODR_12Hz5  =  1,
-  LSM6DS3TR_C_GY_ODR_26Hz   =  2,
-  LSM6DS3TR_C_GY_ODR_52Hz   =  3,
-  LSM6DS3TR_C_GY_ODR_104Hz  =  4,
-  LSM6DS3TR_C_GY_ODR_208Hz  =  5,
-  LSM6DS3TR_C_GY_ODR_416Hz  =  6,
-  LSM6DS3TR_C_GY_ODR_833Hz  =  7,
-  LSM6DS3TR_C_GY_ODR_1k66Hz =  8,
-  LSM6DS3TR_C_GY_ODR_3k33Hz =  9,
-  LSM6DS3TR_C_GY_ODR_6k66Hz = 10,
-  LSM6DS3TR_C_GY_ODR_ND     = 11,    /* ERROR CODE */
-} lsm6ds3tr_c_odr_g_t;
-int32_t lsm6ds3tr_c_gy_data_rate_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_odr_g_t val);
-int32_t lsm6ds3tr_c_gy_data_rate_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_odr_g_t *val);
-
-int32_t lsm6ds3tr_c_block_data_update_set(stmdev_ctx_t *ctx,
-                                          uint8_t val);
-int32_t lsm6ds3tr_c_block_data_update_get(stmdev_ctx_t *ctx,
-                                          uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_LSb_1mg   = 0,
-  LSM6DS3TR_C_LSb_16mg  = 1,
-  LSM6DS3TR_C_WEIGHT_ND = 2,
-} lsm6ds3tr_c_usr_off_w_t;
-int32_t lsm6ds3tr_c_xl_offset_weight_set(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_usr_off_w_t val);
-int32_t lsm6ds3tr_c_xl_offset_weight_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_usr_off_w_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_XL_HIGH_PERFORMANCE  = 0,
-  LSM6DS3TR_C_XL_NORMAL            = 1,
-  LSM6DS3TR_C_XL_PW_MODE_ND        = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_xl_hm_mode_t;
-int32_t lsm6ds3tr_c_xl_power_mode_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_xl_hm_mode_t val);
-int32_t lsm6ds3tr_c_xl_power_mode_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_xl_hm_mode_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_STAT_RND_DISABLE  = 0,
-  LSM6DS3TR_C_STAT_RND_ENABLE   = 1,
-  LSM6DS3TR_C_STAT_RND_ND       = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_rounding_status_t;
-int32_t lsm6ds3tr_c_rounding_on_status_set(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_rounding_status_t val);
-int32_t lsm6ds3tr_c_rounding_on_status_get(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_rounding_status_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_GY_HIGH_PERFORMANCE  = 0,
-  LSM6DS3TR_C_GY_NORMAL            = 1,
-  LSM6DS3TR_C_GY_PW_MODE_ND        = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_g_hm_mode_t;
-int32_t lsm6ds3tr_c_gy_power_mode_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_g_hm_mode_t val);
-int32_t lsm6ds3tr_c_gy_power_mode_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_g_hm_mode_t *val);
-
-typedef struct
-{
-  lsm6ds3tr_c_wake_up_src_t        wake_up_src;
-  lsm6ds3tr_c_tap_src_t            tap_src;
-  lsm6ds3tr_c_d6d_src_t            d6d_src;
-  lsm6ds3tr_c_status_reg_t         status_reg;
-  lsm6ds3tr_c_func_src1_t          func_src1;
-  lsm6ds3tr_c_func_src2_t          func_src2;
-  lsm6ds3tr_c_wrist_tilt_ia_t      wrist_tilt_ia;
-  lsm6ds3tr_c_a_wrist_tilt_mask_t  a_wrist_tilt_mask;
-} lsm6ds3tr_c_all_sources_t;
-int32_t lsm6ds3tr_c_all_sources_get(stmdev_ctx_t *ctx,
-                                    lsm6ds3tr_c_all_sources_t *val);
-
-int32_t lsm6ds3tr_c_status_reg_get(stmdev_ctx_t *ctx,
-                                   lsm6ds3tr_c_status_reg_t *val);
-
-int32_t lsm6ds3tr_c_xl_flag_data_ready_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val);
-
-int32_t lsm6ds3tr_c_gy_flag_data_ready_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val);
-
-int32_t lsm6ds3tr_c_temp_flag_data_ready_get(stmdev_ctx_t *ctx,
-                                             uint8_t *val);
-
-int32_t lsm6ds3tr_c_xl_usr_offset_set(stmdev_ctx_t *ctx,
-                                      uint8_t *buff);
-int32_t lsm6ds3tr_c_xl_usr_offset_get(stmdev_ctx_t *ctx,
-                                      uint8_t *buff);
-int32_t lsm6ds3tr_c_timestamp_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_timestamp_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_LSB_6ms4    = 0,
-  LSM6DS3TR_C_LSB_25us    = 1,
-  LSM6DS3TR_C_TS_RES_ND   = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_timer_hr_t;
-int32_t lsm6ds3tr_c_timestamp_res_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_timer_hr_t val);
-int32_t lsm6ds3tr_c_timestamp_res_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_timer_hr_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_ROUND_DISABLE            = 0,
-  LSM6DS3TR_C_ROUND_XL                 = 1,
-  LSM6DS3TR_C_ROUND_GY                 = 2,
-  LSM6DS3TR_C_ROUND_GY_XL              = 3,
-  LSM6DS3TR_C_ROUND_SH1_TO_SH6         = 4,
-  LSM6DS3TR_C_ROUND_XL_SH1_TO_SH6      = 5,
-  LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH12  = 6,
-  LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH6   = 7,
-  LSM6DS3TR_C_ROUND_OUT_ND             = 8,    /* ERROR CODE */
-} lsm6ds3tr_c_rounding_t;
-int32_t lsm6ds3tr_c_rounding_mode_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_rounding_t val);
-int32_t lsm6ds3tr_c_rounding_mode_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_rounding_t *val);
-
-int32_t lsm6ds3tr_c_temperature_raw_get(stmdev_ctx_t *ctx,
-                                        int16_t *val);
-int32_t lsm6ds3tr_c_angular_rate_raw_get(stmdev_ctx_t *ctx,
-                                         int16_t *val);
-int32_t lsm6ds3tr_c_acceleration_raw_get(stmdev_ctx_t *ctx,
-                                         int16_t *val);
-
-int32_t lsm6ds3tr_c_mag_calibrated_raw_get(stmdev_ctx_t *ctx,
-                                           int16_t *val);
-
-int32_t lsm6ds3tr_c_fifo_raw_data_get(stmdev_ctx_t *ctx,
-                                      uint8_t *buffer,
-                                      uint8_t len);
-
-typedef enum
-{
-  LSM6DS3TR_C_USER_BANK   = 0,
-  LSM6DS3TR_C_BANK_A      = 4,
-  LSM6DS3TR_C_BANK_B      = 5,
-  LSM6DS3TR_C_BANK_ND     = 6,    /* ERROR CODE */
-} lsm6ds3tr_c_func_cfg_en_t;
-int32_t lsm6ds3tr_c_mem_bank_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_func_cfg_en_t val);
-int32_t lsm6ds3tr_c_mem_bank_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_func_cfg_en_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_DRDY_LATCHED    = 0,
-  LSM6DS3TR_C_DRDY_PULSED     = 1,
-  LSM6DS3TR_C_DRDY_ND         = 2,  /* ERROR CODE */
-} lsm6ds3tr_c_drdy_pulsed_g_t;
-int32_t lsm6ds3tr_c_data_ready_mode_set(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_drdy_pulsed_g_t val);
-int32_t lsm6ds3tr_c_data_ready_mode_get(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_drdy_pulsed_g_t *val);
-
-int32_t lsm6ds3tr_c_device_id_get(stmdev_ctx_t *ctx, uint8_t *buff);
-int32_t lsm6ds3tr_c_reset_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_reset_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_LSB_AT_LOW_ADD  = 0,
-  LSM6DS3TR_C_MSB_AT_LOW_ADD  = 1,
-  LSM6DS3TR_C_DATA_FMT_ND     = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_ble_t;
-int32_t lsm6ds3tr_c_data_format_set(stmdev_ctx_t *ctx,
-                                    lsm6ds3tr_c_ble_t val);
-int32_t lsm6ds3tr_c_data_format_get(stmdev_ctx_t *ctx,
-                                    lsm6ds3tr_c_ble_t *val);
-
-int32_t lsm6ds3tr_c_auto_increment_set(stmdev_ctx_t *ctx,
-                                       uint8_t val);
-int32_t lsm6ds3tr_c_auto_increment_get(stmdev_ctx_t *ctx,
-                                       uint8_t *val);
-
-int32_t lsm6ds3tr_c_boot_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_boot_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_XL_ST_DISABLE    = 0,
-  LSM6DS3TR_C_XL_ST_POSITIVE   = 1,
-  LSM6DS3TR_C_XL_ST_NEGATIVE   = 2,
-  LSM6DS3TR_C_XL_ST_ND         = 3,    /* ERROR CODE */
-} lsm6ds3tr_c_st_xl_t;
-int32_t lsm6ds3tr_c_xl_self_test_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_st_xl_t val);
-int32_t lsm6ds3tr_c_xl_self_test_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_st_xl_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_GY_ST_DISABLE    = 0,
-  LSM6DS3TR_C_GY_ST_POSITIVE   = 1,
-  LSM6DS3TR_C_GY_ST_NEGATIVE   = 3,
-  LSM6DS3TR_C_GY_ST_ND         = 4,    /* ERROR CODE */
-} lsm6ds3tr_c_st_g_t;
-int32_t lsm6ds3tr_c_gy_self_test_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_st_g_t val);
-int32_t lsm6ds3tr_c_gy_self_test_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_st_g_t *val);
-
-int32_t lsm6ds3tr_c_filter_settling_mask_set(stmdev_ctx_t *ctx,
-                                             uint8_t val);
-int32_t lsm6ds3tr_c_filter_settling_mask_get(stmdev_ctx_t *ctx,
-                                             uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_USE_SLOPE    = 0,
-  LSM6DS3TR_C_USE_HPF      = 1,
-  LSM6DS3TR_C_HP_PATH_ND   = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_slope_fds_t;
-int32_t lsm6ds3tr_c_xl_hp_path_internal_set(stmdev_ctx_t *ctx,
-                                            lsm6ds3tr_c_slope_fds_t val);
-int32_t lsm6ds3tr_c_xl_hp_path_internal_get(stmdev_ctx_t *ctx,
-                                            lsm6ds3tr_c_slope_fds_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_XL_ANA_BW_1k5Hz = 0,
-  LSM6DS3TR_C_XL_ANA_BW_400Hz = 1,
-  LSM6DS3TR_C_XL_ANA_BW_ND    = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_bw0_xl_t;
-int32_t lsm6ds3tr_c_xl_filter_analog_set(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_bw0_xl_t val);
-int32_t lsm6ds3tr_c_xl_filter_analog_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_bw0_xl_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_XL_LP1_ODR_DIV_2 = 0,
-  LSM6DS3TR_C_XL_LP1_ODR_DIV_4 = 1,
-  LSM6DS3TR_C_XL_LP1_NA        = 2,  /* ERROR CODE */
-} lsm6ds3tr_c_lpf1_bw_sel_t;
-int32_t lsm6ds3tr_c_xl_lp1_bandwidth_set(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_lpf1_bw_sel_t val);
-int32_t lsm6ds3tr_c_xl_lp1_bandwidth_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_lpf1_bw_sel_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_50     = 0x00,
-  LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_100    = 0x01,
-  LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_9      = 0x02,
-  LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_400    = 0x03,
-  LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_50   = 0x10,
-  LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_100  = 0x11,
-  LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_9    = 0x12,
-  LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_400  = 0x13,
-  LSM6DS3TR_C_XL_LP_NA                     = 0x20, /* ERROR CODE */
-} lsm6ds3tr_c_input_composite_t;
-int32_t lsm6ds3tr_c_xl_lp2_bandwidth_set(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_input_composite_t val);
-int32_t lsm6ds3tr_c_xl_lp2_bandwidth_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_input_composite_t *val);
-
-int32_t lsm6ds3tr_c_xl_reference_mode_set(stmdev_ctx_t *ctx,
-                                          uint8_t val);
-int32_t lsm6ds3tr_c_xl_reference_mode_get(stmdev_ctx_t *ctx,
-                                          uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_XL_HP_ODR_DIV_4      = 0x00, /* Slope filter */
-  LSM6DS3TR_C_XL_HP_ODR_DIV_100    = 0x01,
-  LSM6DS3TR_C_XL_HP_ODR_DIV_9      = 0x02,
-  LSM6DS3TR_C_XL_HP_ODR_DIV_400    = 0x03,
-  LSM6DS3TR_C_XL_HP_NA             = 0x10, /* ERROR CODE */
-} lsm6ds3tr_c_hpcf_xl_t;
-int32_t lsm6ds3tr_c_xl_hp_bandwidth_set(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_hpcf_xl_t val);
-int32_t lsm6ds3tr_c_xl_hp_bandwidth_get(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_hpcf_xl_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_LP2_ONLY                    = 0x00,
-
-  LSM6DS3TR_C_HP_16mHz_LP2                = 0x80,
-  LSM6DS3TR_C_HP_65mHz_LP2                = 0x90,
-  LSM6DS3TR_C_HP_260mHz_LP2               = 0xA0,
-  LSM6DS3TR_C_HP_1Hz04_LP2                = 0xB0,
-
-  LSM6DS3TR_C_HP_DISABLE_LP1_LIGHT        = 0x0A,
-  LSM6DS3TR_C_HP_DISABLE_LP1_NORMAL       = 0x09,
-  LSM6DS3TR_C_HP_DISABLE_LP_STRONG        = 0x08,
-  LSM6DS3TR_C_HP_DISABLE_LP1_AGGRESSIVE   = 0x0B,
-
-  LSM6DS3TR_C_HP_16mHz_LP1_LIGHT          = 0x8A,
-  LSM6DS3TR_C_HP_65mHz_LP1_NORMAL         = 0x99,
-  LSM6DS3TR_C_HP_260mHz_LP1_STRONG        = 0xA8,
-  LSM6DS3TR_C_HP_1Hz04_LP1_AGGRESSIVE     = 0xBB,
-
-  LSM6DS3TR_C_HP_GY_BAND_NA               = 0xFF,    /* ERROR CODE */
-} lsm6ds3tr_c_lpf1_sel_g_t;
-int32_t lsm6ds3tr_c_gy_band_pass_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_lpf1_sel_g_t val);
-int32_t lsm6ds3tr_c_gy_band_pass_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_lpf1_sel_g_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_SPI_4_WIRE  = 0,
-  LSM6DS3TR_C_SPI_3_WIRE  = 1,
-  LSM6DS3TR_C_SPI_MODE_ND = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_sim_t;
-int32_t lsm6ds3tr_c_spi_mode_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_sim_t val);
-int32_t lsm6ds3tr_c_spi_mode_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_sim_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_I2C_ENABLE   = 0,
-  LSM6DS3TR_C_I2C_DISABLE  = 1,
-  LSM6DS3TR_C_I2C_MODE_ND  = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_i2c_disable_t;
-int32_t lsm6ds3tr_c_i2c_interface_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_i2c_disable_t val);
-int32_t lsm6ds3tr_c_i2c_interface_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_i2c_disable_t *val);
-
-typedef struct
-{
-  uint8_t int1_drdy_xl             : 1;
-  uint8_t int1_drdy_g              : 1;
-  uint8_t int1_boot                : 1;
-  uint8_t int1_fth                 : 1;
-  uint8_t int1_fifo_ovr            : 1;
-  uint8_t int1_full_flag           : 1;
-  uint8_t int1_sign_mot            : 1;
-  uint8_t int1_step_detector       : 1;
-  uint8_t int1_timer               : 1;
-  uint8_t int1_tilt                : 1;
-  uint8_t int1_6d                  : 1;
-  uint8_t int1_double_tap          : 1;
-  uint8_t int1_ff                  : 1;
-  uint8_t int1_wu                  : 1;
-  uint8_t int1_single_tap          : 1;
-  uint8_t int1_inact_state         : 1;
-  uint8_t den_drdy_int1            : 1;
-  uint8_t drdy_on_int1             : 1;
-} lsm6ds3tr_c_int1_route_t;
-int32_t lsm6ds3tr_c_pin_int1_route_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_int1_route_t val);
-int32_t lsm6ds3tr_c_pin_int1_route_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_int1_route_t *val);
-
-typedef struct
-{
-  uint8_t int2_drdy_xl             : 1;
-  uint8_t int2_drdy_g              : 1;
-  uint8_t int2_drdy_temp           : 1;
-  uint8_t int2_fth                 : 1;
-  uint8_t int2_fifo_ovr            : 1;
-  uint8_t int2_full_flag           : 1;
-  uint8_t int2_step_count_ov       : 1;
-  uint8_t int2_step_delta          : 1;
-  uint8_t int2_iron                : 1;
-  uint8_t int2_tilt                : 1;
-  uint8_t int2_6d                  : 1;
-  uint8_t int2_double_tap          : 1;
-  uint8_t int2_ff                  : 1;
-  uint8_t int2_wu                  : 1;
-  uint8_t int2_single_tap          : 1;
-  uint8_t int2_inact_state         : 1;
-  uint8_t int2_wrist_tilt          : 1;
-} lsm6ds3tr_c_int2_route_t;
-int32_t lsm6ds3tr_c_pin_int2_route_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_int2_route_t val);
-int32_t lsm6ds3tr_c_pin_int2_route_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_int2_route_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_PUSH_PULL   = 0,
-  LSM6DS3TR_C_OPEN_DRAIN  = 1,
-  LSM6DS3TR_C_PIN_MODE_ND = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_pp_od_t;
-int32_t lsm6ds3tr_c_pin_mode_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_pp_od_t val);
-int32_t lsm6ds3tr_c_pin_mode_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_pp_od_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_ACTIVE_HIGH   = 0,
-  LSM6DS3TR_C_ACTIVE_LOW    = 1,
-  LSM6DS3TR_C_POLARITY_ND   = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_h_lactive_t;
-int32_t lsm6ds3tr_c_pin_polarity_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_h_lactive_t val);
-int32_t lsm6ds3tr_c_pin_polarity_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_h_lactive_t *val);
-
-int32_t lsm6ds3tr_c_all_on_int1_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_all_on_int1_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_INT_PULSED   = 0,
-  LSM6DS3TR_C_INT_LATCHED  = 1,
-  LSM6DS3TR_C_INT_MODE     = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_lir_t;
-int32_t lsm6ds3tr_c_int_notification_set(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_lir_t val);
-int32_t lsm6ds3tr_c_int_notification_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_lir_t *val);
-
-int32_t lsm6ds3tr_c_wkup_threshold_set(stmdev_ctx_t *ctx,
-                                       uint8_t val);
-int32_t lsm6ds3tr_c_wkup_threshold_get(stmdev_ctx_t *ctx,
-                                       uint8_t *val);
-
-int32_t lsm6ds3tr_c_wkup_dur_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_wkup_dur_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-int32_t lsm6ds3tr_c_gy_sleep_mode_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_gy_sleep_mode_get(stmdev_ctx_t *ctx,
-                                      uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_PROPERTY_DISABLE          = 0,
-  LSM6DS3TR_C_XL_12Hz5_GY_NOT_AFFECTED  = 1,
-  LSM6DS3TR_C_XL_12Hz5_GY_SLEEP         = 2,
-  LSM6DS3TR_C_XL_12Hz5_GY_PD            = 3,
-  LSM6DS3TR_C_ACT_MODE_ND               = 4,    /* ERROR CODE */
-} lsm6ds3tr_c_inact_en_t;
-int32_t lsm6ds3tr_c_act_mode_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_inact_en_t val);
-int32_t lsm6ds3tr_c_act_mode_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_inact_en_t *val);
-
-int32_t lsm6ds3tr_c_act_sleep_dur_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_act_sleep_dur_get(stmdev_ctx_t *ctx,
-                                      uint8_t *val);
-
-int32_t lsm6ds3tr_c_tap_src_get(stmdev_ctx_t *ctx,
-                                lsm6ds3tr_c_tap_src_t *val);
-
-int32_t lsm6ds3tr_c_tap_detection_on_z_set(stmdev_ctx_t *ctx,
-                                           uint8_t val);
-int32_t lsm6ds3tr_c_tap_detection_on_z_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val);
-
-int32_t lsm6ds3tr_c_tap_detection_on_y_set(stmdev_ctx_t *ctx,
-                                           uint8_t val);
-int32_t lsm6ds3tr_c_tap_detection_on_y_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val);
-
-int32_t lsm6ds3tr_c_tap_detection_on_x_set(stmdev_ctx_t *ctx,
-                                           uint8_t val);
-int32_t lsm6ds3tr_c_tap_detection_on_x_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val);
-
-int32_t lsm6ds3tr_c_tap_threshold_x_set(stmdev_ctx_t *ctx,
-                                        uint8_t val);
-int32_t lsm6ds3tr_c_tap_threshold_x_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val);
-
-int32_t lsm6ds3tr_c_tap_shock_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_tap_shock_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-int32_t lsm6ds3tr_c_tap_quiet_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_tap_quiet_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-int32_t lsm6ds3tr_c_tap_dur_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_tap_dur_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_ONLY_SINGLE          = 0,
-  LSM6DS3TR_C_BOTH_SINGLE_DOUBLE   = 1,
-  LSM6DS3TR_C_TAP_MODE_ND          = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_single_double_tap_t;
-int32_t lsm6ds3tr_c_tap_mode_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_single_double_tap_t val);
-int32_t lsm6ds3tr_c_tap_mode_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_single_double_tap_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_ODR_DIV_2_FEED      = 0,
-  LSM6DS3TR_C_LPF2_FEED           = 1,
-  LSM6DS3TR_C_6D_FEED_ND          = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_low_pass_on_6d_t;
-int32_t lsm6ds3tr_c_6d_feed_data_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_low_pass_on_6d_t val);
-int32_t lsm6ds3tr_c_6d_feed_data_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_low_pass_on_6d_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_DEG_80      = 0,
-  LSM6DS3TR_C_DEG_70      = 1,
-  LSM6DS3TR_C_DEG_60      = 2,
-  LSM6DS3TR_C_DEG_50      = 3,
-  LSM6DS3TR_C_6D_TH_ND    = 4,    /* ERROR CODE */
-} lsm6ds3tr_c_sixd_ths_t;
-int32_t lsm6ds3tr_c_6d_threshold_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sixd_ths_t val);
-int32_t lsm6ds3tr_c_6d_threshold_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sixd_ths_t *val);
-
-int32_t lsm6ds3tr_c_4d_mode_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_4d_mode_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-int32_t lsm6ds3tr_c_ff_dur_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_ff_dur_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_FF_TSH_156mg = 0,
-  LSM6DS3TR_C_FF_TSH_219mg = 1,
-  LSM6DS3TR_C_FF_TSH_250mg = 2,
-  LSM6DS3TR_C_FF_TSH_312mg = 3,
-  LSM6DS3TR_C_FF_TSH_344mg = 4,
-  LSM6DS3TR_C_FF_TSH_406mg = 5,
-  LSM6DS3TR_C_FF_TSH_469mg = 6,
-  LSM6DS3TR_C_FF_TSH_500mg = 7,
-  LSM6DS3TR_C_FF_TSH_ND    = 8,    /* ERROR CODE */
-} lsm6ds3tr_c_ff_ths_t;
-int32_t lsm6ds3tr_c_ff_threshold_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_ff_ths_t val);
-int32_t lsm6ds3tr_c_ff_threshold_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_ff_ths_t *val);
-
-int32_t lsm6ds3tr_c_fifo_watermark_set(stmdev_ctx_t *ctx,
-                                       uint16_t val);
-int32_t lsm6ds3tr_c_fifo_watermark_get(stmdev_ctx_t *ctx,
-                                       uint16_t *val);
-
-int32_t lsm6ds3tr_c_fifo_data_level_get(stmdev_ctx_t *ctx,
-                                        uint16_t *val);
-
-int32_t lsm6ds3tr_c_fifo_wtm_flag_get(stmdev_ctx_t *ctx,
-                                      uint8_t *val);
-
-int32_t lsm6ds3tr_c_fifo_pattern_get(stmdev_ctx_t *ctx,
-                                     uint16_t *val);
-
-int32_t lsm6ds3tr_c_fifo_temp_batch_set(stmdev_ctx_t *ctx,
-                                        uint8_t val);
-int32_t lsm6ds3tr_c_fifo_temp_batch_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_TRG_XL_GY_DRDY     = 0,
-  LSM6DS3TR_C_TRG_STEP_DETECT    = 1,
-  LSM6DS3TR_C_TRG_SH_DRDY        = 2,
-  LSM6DS3TR_C_TRG_SH_ND          = 3,    /* ERROR CODE */
-} lsm6ds3tr_c_trigger_fifo_t;
-int32_t lsm6ds3tr_c_fifo_write_trigger_set(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_trigger_fifo_t val);
-int32_t lsm6ds3tr_c_fifo_write_trigger_get(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_trigger_fifo_t *val);
-
-int32_t lsm6ds3tr_c_fifo_pedo_and_timestamp_batch_set(
-  stmdev_ctx_t *ctx,
-  uint8_t val);
-int32_t lsm6ds3tr_c_fifo_pedo_and_timestamp_batch_get(
-  stmdev_ctx_t *ctx,
-  uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_FIFO_XL_DISABLE  = 0,
-  LSM6DS3TR_C_FIFO_XL_NO_DEC   = 1,
-  LSM6DS3TR_C_FIFO_XL_DEC_2    = 2,
-  LSM6DS3TR_C_FIFO_XL_DEC_3    = 3,
-  LSM6DS3TR_C_FIFO_XL_DEC_4    = 4,
-  LSM6DS3TR_C_FIFO_XL_DEC_8    = 5,
-  LSM6DS3TR_C_FIFO_XL_DEC_16   = 6,
-  LSM6DS3TR_C_FIFO_XL_DEC_32   = 7,
-  LSM6DS3TR_C_FIFO_XL_DEC_ND   = 8,    /* ERROR CODE */
-} lsm6ds3tr_c_dec_fifo_xl_t;
-int32_t lsm6ds3tr_c_fifo_xl_batch_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_dec_fifo_xl_t val);
-int32_t lsm6ds3tr_c_fifo_xl_batch_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_dec_fifo_xl_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_FIFO_GY_DISABLE = 0,
-  LSM6DS3TR_C_FIFO_GY_NO_DEC  = 1,
-  LSM6DS3TR_C_FIFO_GY_DEC_2   = 2,
-  LSM6DS3TR_C_FIFO_GY_DEC_3   = 3,
-  LSM6DS3TR_C_FIFO_GY_DEC_4   = 4,
-  LSM6DS3TR_C_FIFO_GY_DEC_8   = 5,
-  LSM6DS3TR_C_FIFO_GY_DEC_16  = 6,
-  LSM6DS3TR_C_FIFO_GY_DEC_32  = 7,
-  LSM6DS3TR_C_FIFO_GY_DEC_ND  = 8,    /* ERROR CODE */
-} lsm6ds3tr_c_dec_fifo_gyro_t;
-int32_t lsm6ds3tr_c_fifo_gy_batch_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_dec_fifo_gyro_t val);
-int32_t lsm6ds3tr_c_fifo_gy_batch_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_dec_fifo_gyro_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_FIFO_DS3_DISABLE   = 0,
-  LSM6DS3TR_C_FIFO_DS3_NO_DEC    = 1,
-  LSM6DS3TR_C_FIFO_DS3_DEC_2     = 2,
-  LSM6DS3TR_C_FIFO_DS3_DEC_3     = 3,
-  LSM6DS3TR_C_FIFO_DS3_DEC_4     = 4,
-  LSM6DS3TR_C_FIFO_DS3_DEC_8     = 5,
-  LSM6DS3TR_C_FIFO_DS3_DEC_16    = 6,
-  LSM6DS3TR_C_FIFO_DS3_DEC_32    = 7,
-  LSM6DS3TR_C_FIFO_DS3_DEC_ND    = 8,    /* ERROR CODE */
-} lsm6ds3tr_c_dec_ds3_fifo_t;
-int32_t lsm6ds3tr_c_fifo_dataset_3_batch_set(stmdev_ctx_t *ctx,
-                                             lsm6ds3tr_c_dec_ds3_fifo_t val);
-int32_t lsm6ds3tr_c_fifo_dataset_3_batch_get(stmdev_ctx_t *ctx,
-                                             lsm6ds3tr_c_dec_ds3_fifo_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_FIFO_DS4_DISABLE  = 0,
-  LSM6DS3TR_C_FIFO_DS4_NO_DEC   = 1,
-  LSM6DS3TR_C_FIFO_DS4_DEC_2    = 2,
-  LSM6DS3TR_C_FIFO_DS4_DEC_3    = 3,
-  LSM6DS3TR_C_FIFO_DS4_DEC_4    = 4,
-  LSM6DS3TR_C_FIFO_DS4_DEC_8    = 5,
-  LSM6DS3TR_C_FIFO_DS4_DEC_16   = 6,
-  LSM6DS3TR_C_FIFO_DS4_DEC_32   = 7,
-  LSM6DS3TR_C_FIFO_DS4_DEC_ND   = 8,    /* ERROR CODE */
-} lsm6ds3tr_c_dec_ds4_fifo_t;
-int32_t lsm6ds3tr_c_fifo_dataset_4_batch_set(stmdev_ctx_t *ctx,
-                                             lsm6ds3tr_c_dec_ds4_fifo_t val);
-int32_t lsm6ds3tr_c_fifo_dataset_4_batch_get(stmdev_ctx_t *ctx,
-                                             lsm6ds3tr_c_dec_ds4_fifo_t *val);
-
-int32_t lsm6ds3tr_c_fifo_xl_gy_8bit_format_set(stmdev_ctx_t *ctx,
-                                               uint8_t val);
-int32_t lsm6ds3tr_c_fifo_xl_gy_8bit_format_get(stmdev_ctx_t *ctx,
-                                               uint8_t *val);
-
-int32_t lsm6ds3tr_c_fifo_stop_on_wtm_set(stmdev_ctx_t *ctx,
-                                         uint8_t val);
-int32_t lsm6ds3tr_c_fifo_stop_on_wtm_get(stmdev_ctx_t *ctx,
-                                         uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_BYPASS_MODE           = 0,
-  LSM6DS3TR_C_FIFO_MODE             = 1,
-  LSM6DS3TR_C_STREAM_TO_FIFO_MODE   = 3,
-  LSM6DS3TR_C_BYPASS_TO_STREAM_MODE = 4,
-  LSM6DS3TR_C_STREAM_MODE           = 6,
-  LSM6DS3TR_C_FIFO_MODE_ND          = 8,    /* ERROR CODE */
-} lsm6ds3tr_c_fifo_mode_t;
-int32_t lsm6ds3tr_c_fifo_mode_set(stmdev_ctx_t *ctx,
-                                  lsm6ds3tr_c_fifo_mode_t val);
-int32_t lsm6ds3tr_c_fifo_mode_get(stmdev_ctx_t *ctx,
-                                  lsm6ds3tr_c_fifo_mode_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_FIFO_DISABLE   =  0,
-  LSM6DS3TR_C_FIFO_12Hz5     =  1,
-  LSM6DS3TR_C_FIFO_26Hz      =  2,
-  LSM6DS3TR_C_FIFO_52Hz      =  3,
-  LSM6DS3TR_C_FIFO_104Hz     =  4,
-  LSM6DS3TR_C_FIFO_208Hz     =  5,
-  LSM6DS3TR_C_FIFO_416Hz     =  6,
-  LSM6DS3TR_C_FIFO_833Hz     =  7,
-  LSM6DS3TR_C_FIFO_1k66Hz    =  8,
-  LSM6DS3TR_C_FIFO_3k33Hz    =  9,
-  LSM6DS3TR_C_FIFO_6k66Hz    = 10,
-  LSM6DS3TR_C_FIFO_RATE_ND   = 11,    /* ERROR CODE */
-} lsm6ds3tr_c_odr_fifo_t;
-int32_t lsm6ds3tr_c_fifo_data_rate_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_odr_fifo_t val);
-int32_t lsm6ds3tr_c_fifo_data_rate_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_odr_fifo_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_DEN_ACT_LOW    = 0,
-  LSM6DS3TR_C_DEN_ACT_HIGH   = 1,
-  LSM6DS3TR_C_DEN_POL_ND     = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_den_lh_t;
-int32_t lsm6ds3tr_c_den_polarity_set(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_den_lh_t val);
-int32_t lsm6ds3tr_c_den_polarity_get(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_den_lh_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_DEN_DISABLE    = 0,
-  LSM6DS3TR_C_LEVEL_FIFO     = 6,
-  LSM6DS3TR_C_LEVEL_LETCHED  = 3,
-  LSM6DS3TR_C_LEVEL_TRIGGER  = 2,
-  LSM6DS3TR_C_EDGE_TRIGGER   = 4,
-  LSM6DS3TR_C_DEN_MODE_ND    = 5,    /* ERROR CODE */
-} lsm6ds3tr_c_den_mode_t;
-int32_t lsm6ds3tr_c_den_mode_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_den_mode_t val);
-int32_t lsm6ds3tr_c_den_mode_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_den_mode_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_STAMP_IN_GY_DATA     = 0,
-  LSM6DS3TR_C_STAMP_IN_XL_DATA     = 1,
-  LSM6DS3TR_C_STAMP_IN_GY_XL_DATA  = 2,
-  LSM6DS3TR_C_DEN_STAMP_ND         = 3,    /* ERROR CODE */
-} lsm6ds3tr_c_den_xl_en_t;
-int32_t lsm6ds3tr_c_den_enable_set(stmdev_ctx_t *ctx,
-                                   lsm6ds3tr_c_den_xl_en_t val);
-int32_t lsm6ds3tr_c_den_enable_get(stmdev_ctx_t *ctx,
-                                   lsm6ds3tr_c_den_xl_en_t *val);
-
-int32_t lsm6ds3tr_c_den_mark_axis_z_set(stmdev_ctx_t *ctx,
-                                        uint8_t val);
-int32_t lsm6ds3tr_c_den_mark_axis_z_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val);
-
-int32_t lsm6ds3tr_c_den_mark_axis_y_set(stmdev_ctx_t *ctx,
-                                        uint8_t val);
-int32_t lsm6ds3tr_c_den_mark_axis_y_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val);
-
-int32_t lsm6ds3tr_c_den_mark_axis_x_set(stmdev_ctx_t *ctx,
-                                        uint8_t val);
-int32_t lsm6ds3tr_c_den_mark_axis_x_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val);
-
-int32_t lsm6ds3tr_c_pedo_step_reset_set(stmdev_ctx_t *ctx,
-                                        uint8_t val);
-int32_t lsm6ds3tr_c_pedo_step_reset_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val);
-
-int32_t lsm6ds3tr_c_pedo_sens_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_pedo_sens_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-int32_t lsm6ds3tr_c_pedo_threshold_set(stmdev_ctx_t *ctx,
-                                       uint8_t val);
-int32_t lsm6ds3tr_c_pedo_threshold_get(stmdev_ctx_t *ctx,
-                                       uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_PEDO_AT_2g = 0,
-  LSM6DS3TR_C_PEDO_AT_4g = 1,
-  LSM6DS3TR_C_PEDO_FS_ND = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_pedo_fs_t;
-int32_t lsm6ds3tr_c_pedo_full_scale_set(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_pedo_fs_t val);
-int32_t lsm6ds3tr_c_pedo_full_scale_get(stmdev_ctx_t *ctx,
-                                        lsm6ds3tr_c_pedo_fs_t *val);
-
-int32_t lsm6ds3tr_c_pedo_debounce_steps_set(stmdev_ctx_t *ctx,
-                                            uint8_t val);
-int32_t lsm6ds3tr_c_pedo_debounce_steps_get(stmdev_ctx_t *ctx,
-                                            uint8_t *val);
-
-int32_t lsm6ds3tr_c_pedo_timeout_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_pedo_timeout_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-int32_t lsm6ds3tr_c_pedo_steps_period_set(stmdev_ctx_t *ctx,
-                                          uint8_t *buff);
-int32_t lsm6ds3tr_c_pedo_steps_period_get(stmdev_ctx_t *ctx,
-                                          uint8_t *buff);
-
-int32_t lsm6ds3tr_c_motion_sens_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_motion_sens_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-int32_t lsm6ds3tr_c_motion_threshold_set(stmdev_ctx_t *ctx,
-                                         uint8_t *buff);
-int32_t lsm6ds3tr_c_motion_threshold_get(stmdev_ctx_t *ctx,
-                                         uint8_t *buff);
-
-int32_t lsm6ds3tr_c_tilt_sens_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_tilt_sens_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-int32_t lsm6ds3tr_c_wrist_tilt_sens_set(stmdev_ctx_t *ctx,
-                                        uint8_t val);
-int32_t lsm6ds3tr_c_wrist_tilt_sens_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val);
-
-int32_t lsm6ds3tr_c_tilt_latency_set(stmdev_ctx_t *ctx,
-                                     uint8_t *buff);
-int32_t lsm6ds3tr_c_tilt_latency_get(stmdev_ctx_t *ctx,
-                                     uint8_t *buff);
-
-int32_t lsm6ds3tr_c_tilt_threshold_set(stmdev_ctx_t *ctx,
-                                       uint8_t *buff);
-int32_t lsm6ds3tr_c_tilt_threshold_get(stmdev_ctx_t *ctx,
-                                       uint8_t *buff);
-
-int32_t lsm6ds3tr_c_tilt_src_set(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_a_wrist_tilt_mask_t *val);
-int32_t lsm6ds3tr_c_tilt_src_get(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_a_wrist_tilt_mask_t *val);
-
-int32_t lsm6ds3tr_c_mag_soft_iron_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_mag_soft_iron_get(stmdev_ctx_t *ctx,
-                                      uint8_t *val);
-
-int32_t lsm6ds3tr_c_mag_hard_iron_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_mag_hard_iron_get(stmdev_ctx_t *ctx,
-                                      uint8_t *val);
-
-int32_t lsm6ds3tr_c_mag_soft_iron_mat_set(stmdev_ctx_t *ctx,
-                                          uint8_t *buff);
-int32_t lsm6ds3tr_c_mag_soft_iron_mat_get(stmdev_ctx_t *ctx,
-                                          uint8_t *buff);
-
-int32_t lsm6ds3tr_c_mag_offset_set(stmdev_ctx_t *ctx, int16_t *val);
-int32_t lsm6ds3tr_c_mag_offset_get(stmdev_ctx_t *ctx, int16_t *val);
-
-int32_t lsm6ds3tr_c_func_en_set(stmdev_ctx_t *ctx, uint8_t val);
-
-int32_t lsm6ds3tr_c_sh_sync_sens_frame_set(stmdev_ctx_t *ctx,
-                                           uint8_t val);
-int32_t lsm6ds3tr_c_sh_sync_sens_frame_get(stmdev_ctx_t *ctx,
-                                           uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_RES_RATIO_2_11  = 0,
-  LSM6DS3TR_C_RES_RATIO_2_12  = 1,
-  LSM6DS3TR_C_RES_RATIO_2_13  = 2,
-  LSM6DS3TR_C_RES_RATIO_2_14  = 3,
-  LSM6DS3TR_C_RES_RATIO_ND    = 4,    /* ERROR CODE */
-} lsm6ds3tr_c_rr_t;
-int32_t lsm6ds3tr_c_sh_sync_sens_ratio_set(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_rr_t val);
-int32_t lsm6ds3tr_c_sh_sync_sens_ratio_get(stmdev_ctx_t *ctx,
-                                           lsm6ds3tr_c_rr_t *val);
-
-int32_t lsm6ds3tr_c_sh_master_set(stmdev_ctx_t *ctx, uint8_t val);
-int32_t lsm6ds3tr_c_sh_master_get(stmdev_ctx_t *ctx, uint8_t *val);
-
-int32_t lsm6ds3tr_c_sh_pass_through_set(stmdev_ctx_t *ctx,
-                                        uint8_t val);
-int32_t lsm6ds3tr_c_sh_pass_through_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_EXT_PULL_UP       = 0,
-  LSM6DS3TR_C_INTERNAL_PULL_UP  = 1,
-  LSM6DS3TR_C_SH_PIN_MODE       = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_pull_up_en_t;
-int32_t lsm6ds3tr_c_sh_pin_mode_set(stmdev_ctx_t *ctx,
-                                    lsm6ds3tr_c_pull_up_en_t val);
-int32_t lsm6ds3tr_c_sh_pin_mode_get(stmdev_ctx_t *ctx,
-                                    lsm6ds3tr_c_pull_up_en_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_XL_GY_DRDY        = 0,
-  LSM6DS3TR_C_EXT_ON_INT2_PIN   = 1,
-  LSM6DS3TR_C_SH_SYNCRO_ND      = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_start_config_t;
-int32_t lsm6ds3tr_c_sh_syncro_mode_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_start_config_t val);
-int32_t lsm6ds3tr_c_sh_syncro_mode_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_start_config_t *val);
-
-int32_t lsm6ds3tr_c_sh_drdy_on_int1_set(stmdev_ctx_t *ctx,
-                                        uint8_t val);
-int32_t lsm6ds3tr_c_sh_drdy_on_int1_get(stmdev_ctx_t *ctx,
-                                        uint8_t *val);
-
-typedef struct
-{
-  lsm6ds3tr_c_sensorhub1_reg_t   sh_byte_1;
-  lsm6ds3tr_c_sensorhub2_reg_t   sh_byte_2;
-  lsm6ds3tr_c_sensorhub3_reg_t   sh_byte_3;
-  lsm6ds3tr_c_sensorhub4_reg_t   sh_byte_4;
-  lsm6ds3tr_c_sensorhub5_reg_t   sh_byte_5;
-  lsm6ds3tr_c_sensorhub6_reg_t   sh_byte_6;
-  lsm6ds3tr_c_sensorhub7_reg_t   sh_byte_7;
-  lsm6ds3tr_c_sensorhub8_reg_t   sh_byte_8;
-  lsm6ds3tr_c_sensorhub9_reg_t   sh_byte_9;
-  lsm6ds3tr_c_sensorhub10_reg_t  sh_byte_10;
-  lsm6ds3tr_c_sensorhub11_reg_t  sh_byte_11;
-  lsm6ds3tr_c_sensorhub12_reg_t  sh_byte_12;
-  lsm6ds3tr_c_sensorhub13_reg_t  sh_byte_13;
-  lsm6ds3tr_c_sensorhub14_reg_t  sh_byte_14;
-  lsm6ds3tr_c_sensorhub15_reg_t  sh_byte_15;
-  lsm6ds3tr_c_sensorhub16_reg_t  sh_byte_16;
-  lsm6ds3tr_c_sensorhub17_reg_t  sh_byte_17;
-  lsm6ds3tr_c_sensorhub18_reg_t  sh_byte_18;
-} lsm6ds3tr_c_emb_sh_read_t;
-int32_t lsm6ds3tr_c_sh_read_data_raw_get(stmdev_ctx_t *ctx,
-                                         lsm6ds3tr_c_emb_sh_read_t *val);
-
-int32_t lsm6ds3tr_c_sh_cmd_sens_sync_set(stmdev_ctx_t *ctx,
-                                         uint8_t val);
-int32_t lsm6ds3tr_c_sh_cmd_sens_sync_get(stmdev_ctx_t *ctx,
-                                         uint8_t *val);
-
-int32_t lsm6ds3tr_c_sh_spi_sync_error_set(stmdev_ctx_t *ctx,
-                                          uint8_t val);
-int32_t lsm6ds3tr_c_sh_spi_sync_error_get(stmdev_ctx_t *ctx,
-                                          uint8_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_SLV_0        = 0,
-  LSM6DS3TR_C_SLV_0_1      = 1,
-  LSM6DS3TR_C_SLV_0_1_2    = 2,
-  LSM6DS3TR_C_SLV_0_1_2_3  = 3,
-  LSM6DS3TR_C_SLV_EN_ND    = 4,    /* ERROR CODE */
-} lsm6ds3tr_c_aux_sens_on_t;
-int32_t lsm6ds3tr_c_sh_num_of_dev_connected_set(stmdev_ctx_t *ctx,
-                                                lsm6ds3tr_c_aux_sens_on_t val);
-int32_t lsm6ds3tr_c_sh_num_of_dev_connected_get(stmdev_ctx_t *ctx,
-                                                lsm6ds3tr_c_aux_sens_on_t *val);
-
-typedef struct
-{
-  uint8_t   slv0_add;
-  uint8_t   slv0_subadd;
-  uint8_t   slv0_data;
-} lsm6ds3tr_c_sh_cfg_write_t;
-int32_t lsm6ds3tr_c_sh_cfg_write(stmdev_ctx_t *ctx,
-                                 lsm6ds3tr_c_sh_cfg_write_t *val);
-
-typedef struct
-{
-  uint8_t   slv_add;
-  uint8_t   slv_subadd;
-  uint8_t   slv_len;
-} lsm6ds3tr_c_sh_cfg_read_t;
-int32_t lsm6ds3tr_c_sh_slv0_cfg_read(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sh_cfg_read_t *val);
-int32_t lsm6ds3tr_c_sh_slv1_cfg_read(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sh_cfg_read_t *val);
-int32_t lsm6ds3tr_c_sh_slv2_cfg_read(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sh_cfg_read_t *val);
-int32_t lsm6ds3tr_c_sh_slv3_cfg_read(stmdev_ctx_t *ctx,
-                                     lsm6ds3tr_c_sh_cfg_read_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_SL0_NO_DEC   = 0,
-  LSM6DS3TR_C_SL0_DEC_2    = 1,
-  LSM6DS3TR_C_SL0_DEC_4    = 2,
-  LSM6DS3TR_C_SL0_DEC_8    = 3,
-  LSM6DS3TR_C_SL0_DEC_ND   = 4,    /* ERROR CODE */
-} lsm6ds3tr_c_slave0_rate_t;
-int32_t lsm6ds3tr_c_sh_slave_0_dec_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave0_rate_t val);
-int32_t lsm6ds3tr_c_sh_slave_0_dec_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave0_rate_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_EACH_SH_CYCLE     = 0,
-  LSM6DS3TR_C_ONLY_FIRST_CYCLE  = 1,
-  LSM6DS3TR_C_SH_WR_MODE_ND     = 2,    /* ERROR CODE */
-} lsm6ds3tr_c_write_once_t;
-int32_t lsm6ds3tr_c_sh_write_mode_set(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_write_once_t val);
-int32_t lsm6ds3tr_c_sh_write_mode_get(stmdev_ctx_t *ctx,
-                                      lsm6ds3tr_c_write_once_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_SL1_NO_DEC   = 0,
-  LSM6DS3TR_C_SL1_DEC_2    = 1,
-  LSM6DS3TR_C_SL1_DEC_4    = 2,
-  LSM6DS3TR_C_SL1_DEC_8    = 3,
-  LSM6DS3TR_C_SL1_DEC_ND   = 4,    /* ERROR CODE */
-} lsm6ds3tr_c_slave1_rate_t;
-int32_t lsm6ds3tr_c_sh_slave_1_dec_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave1_rate_t val);
-int32_t lsm6ds3tr_c_sh_slave_1_dec_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave1_rate_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_SL2_NO_DEC  = 0,
-  LSM6DS3TR_C_SL2_DEC_2   = 1,
-  LSM6DS3TR_C_SL2_DEC_4   = 2,
-  LSM6DS3TR_C_SL2_DEC_8   = 3,
-  LSM6DS3TR_C_SL2_DEC_ND  = 4,    /* ERROR CODE */
-} lsm6ds3tr_c_slave2_rate_t;
-int32_t lsm6ds3tr_c_sh_slave_2_dec_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave2_rate_t val);
-int32_t lsm6ds3tr_c_sh_slave_2_dec_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave2_rate_t *val);
-
-typedef enum
-{
-  LSM6DS3TR_C_SL3_NO_DEC  = 0,
-  LSM6DS3TR_C_SL3_DEC_2   = 1,
-  LSM6DS3TR_C_SL3_DEC_4   = 2,
-  LSM6DS3TR_C_SL3_DEC_8   = 3,
-  LSM6DS3TR_C_SL3_DEC_ND  = 4,    /* ERROR CODE */
-} lsm6ds3tr_c_slave3_rate_t;
-int32_t lsm6ds3tr_c_sh_slave_3_dec_set(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave3_rate_t val);
-int32_t lsm6ds3tr_c_sh_slave_3_dec_get(stmdev_ctx_t *ctx,
-                                       lsm6ds3tr_c_slave3_rate_t *val);
-
-/**
-  * @}
-  *
-  */
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* LSM6DS3TR_C_DRIVER_H */
-
-/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/

+ 7105 - 0
tracking/imu/lsm6ds3tr_c_reg.c

@@ -0,0 +1,7105 @@
+/**
+  ******************************************************************************
+  * @file    lsm6ds3tr_c_reg.c
+  * @author  Sensors Software Solution Team
+  * @brief   LSM6DS3TR_C driver file
+  ******************************************************************************
+  * @attention
+  *
+  * <h2><center>&copy; Copyright (c) 2021 STMicroelectronics.
+  * All rights reserved.</center></h2>
+  *
+  * This software component is licensed by ST under BSD 3-Clause license,
+  * the "License"; You may not use this file except in compliance with the
+  * License. You may obtain a copy of the License at:
+  *                        opensource.org/licenses/BSD-3-Clause
+  *
+  ******************************************************************************
+  */
+
+#include "lsm6ds3tr_c_reg.h"
+
+/**
+  * @defgroup    LSM6DS3TR_C
+  * @brief       This file provides a set of functions needed to drive the
+  *              lsm6ds3tr_c enanced inertial module.
+  * @{
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_interfaces_functions
+  * @brief       This section provide a set of functions used to read and
+  *              write a generic register of the device.
+  *              MANDATORY: return 0 -> no Error.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Read generic device register
+  *
+  * @param  ctx   read / write interface definitions(ptr)
+  * @param  reg   register to read
+  * @param  data  pointer to buffer that store the data read(ptr)
+  * @param  len   number of consecutive register to read
+  * @retval       interface status (MANDATORY: return 0 -> no Error)
+  *
+  */
+int32_t lsm6ds3tr_c_read_reg(stmdev_ctx_t* ctx, uint8_t reg, uint8_t* data, uint16_t len) {
+    int32_t ret;
+
+    ret = ctx->read_reg(ctx->handle, reg, data, len);
+
+    return ret;
+}
+
+/**
+  * @brief  Write generic device register
+  *
+  * @param  ctx   read / write interface definitions(ptr)
+  * @param  reg   register to write
+  * @param  data  pointer to data to write in register reg(ptr)
+  * @param  len   number of consecutive register to write
+  * @retval       interface status (MANDATORY: return 0 -> no Error)
+  *
+  */
+int32_t lsm6ds3tr_c_write_reg(stmdev_ctx_t* ctx, uint8_t reg, uint8_t* data, uint16_t len) {
+    int32_t ret;
+
+    ret = ctx->write_reg(ctx->handle, reg, data, len);
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_Sensitivity
+  * @brief       These functions convert raw-data into engineering units.
+  * @{
+  *
+  */
+
+float_t lsm6ds3tr_c_from_fs2g_to_mg(int16_t lsb) {
+    return ((float_t)lsb * 0.061f);
+}
+
+float_t lsm6ds3tr_c_from_fs4g_to_mg(int16_t lsb) {
+    return ((float_t)lsb * 0.122f);
+}
+
+float_t lsm6ds3tr_c_from_fs8g_to_mg(int16_t lsb) {
+    return ((float_t)lsb * 0.244f);
+}
+
+float_t lsm6ds3tr_c_from_fs16g_to_mg(int16_t lsb) {
+    return ((float_t)lsb * 0.488f);
+}
+
+float_t lsm6ds3tr_c_from_fs125dps_to_mdps(int16_t lsb) {
+    return ((float_t)lsb * 4.375f);
+}
+
+float_t lsm6ds3tr_c_from_fs250dps_to_mdps(int16_t lsb) {
+    return ((float_t)lsb * 8.750f);
+}
+
+float_t lsm6ds3tr_c_from_fs500dps_to_mdps(int16_t lsb) {
+    return ((float_t)lsb * 17.50f);
+}
+
+float_t lsm6ds3tr_c_from_fs1000dps_to_mdps(int16_t lsb) {
+    return ((float_t)lsb * 35.0f);
+}
+
+float_t lsm6ds3tr_c_from_fs2000dps_to_mdps(int16_t lsb) {
+    return ((float_t)lsb * 70.0f);
+}
+
+float_t lsm6ds3tr_c_from_lsb_to_celsius(int16_t lsb) {
+    return (((float_t)lsb / 256.0f) + 25.0f);
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_data_generation
+  * @brief       This section groups all the functions concerning data
+  *              generation
+  * @{
+  *
+  */
+
+/**
+  * @brief  Accelerometer full-scale selection.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of fs_xl in reg CTRL1_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_full_scale_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_fs_xl_t val) {
+    lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+
+    if(ret == 0) {
+        ctrl1_xl.fs_xl = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Accelerometer full-scale selection.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of fs_xl in reg CTRL1_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_full_scale_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_fs_xl_t* val) {
+    lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+
+    switch(ctrl1_xl.fs_xl) {
+    case LSM6DS3TR_C_2g:
+        *val = LSM6DS3TR_C_2g;
+        break;
+
+    case LSM6DS3TR_C_16g:
+        *val = LSM6DS3TR_C_16g;
+        break;
+
+    case LSM6DS3TR_C_4g:
+        *val = LSM6DS3TR_C_4g;
+        break;
+
+    case LSM6DS3TR_C_8g:
+        *val = LSM6DS3TR_C_8g;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_XL_FS_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Accelerometer data rate selection.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of odr_xl in reg CTRL1_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_data_rate_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_xl_t val) {
+    lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+
+    if(ret == 0) {
+        ctrl1_xl.odr_xl = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Accelerometer data rate selection.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of odr_xl in reg CTRL1_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_data_rate_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_xl_t* val) {
+    lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+
+    switch(ctrl1_xl.odr_xl) {
+    case LSM6DS3TR_C_XL_ODR_OFF:
+        *val = LSM6DS3TR_C_XL_ODR_OFF;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_12Hz5:
+        *val = LSM6DS3TR_C_XL_ODR_12Hz5;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_26Hz:
+        *val = LSM6DS3TR_C_XL_ODR_26Hz;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_52Hz:
+        *val = LSM6DS3TR_C_XL_ODR_52Hz;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_104Hz:
+        *val = LSM6DS3TR_C_XL_ODR_104Hz;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_208Hz:
+        *val = LSM6DS3TR_C_XL_ODR_208Hz;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_416Hz:
+        *val = LSM6DS3TR_C_XL_ODR_416Hz;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_833Hz:
+        *val = LSM6DS3TR_C_XL_ODR_833Hz;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_1k66Hz:
+        *val = LSM6DS3TR_C_XL_ODR_1k66Hz;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_3k33Hz:
+        *val = LSM6DS3TR_C_XL_ODR_3k33Hz;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_6k66Hz:
+        *val = LSM6DS3TR_C_XL_ODR_6k66Hz;
+        break;
+
+    case LSM6DS3TR_C_XL_ODR_1Hz6:
+        *val = LSM6DS3TR_C_XL_ODR_1Hz6;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_XL_ODR_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Gyroscope chain full-scale selection.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of fs_g in reg CTRL2_G
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_full_scale_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_fs_g_t val) {
+    lsm6ds3tr_c_ctrl2_g_t ctrl2_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL2_G, (uint8_t*)&ctrl2_g, 1);
+
+    if(ret == 0) {
+        ctrl2_g.fs_g = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL2_G, (uint8_t*)&ctrl2_g, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Gyroscope chain full-scale selection.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of fs_g in reg CTRL2_G
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_full_scale_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_fs_g_t* val) {
+    lsm6ds3tr_c_ctrl2_g_t ctrl2_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL2_G, (uint8_t*)&ctrl2_g, 1);
+
+    switch(ctrl2_g.fs_g) {
+    case LSM6DS3TR_C_250dps:
+        *val = LSM6DS3TR_C_250dps;
+        break;
+
+    case LSM6DS3TR_C_125dps:
+        *val = LSM6DS3TR_C_125dps;
+        break;
+
+    case LSM6DS3TR_C_500dps:
+        *val = LSM6DS3TR_C_500dps;
+        break;
+
+    case LSM6DS3TR_C_1000dps:
+        *val = LSM6DS3TR_C_1000dps;
+        break;
+
+    case LSM6DS3TR_C_2000dps:
+        *val = LSM6DS3TR_C_2000dps;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_GY_FS_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Gyroscope data rate selection.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of odr_g in reg CTRL2_G
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_data_rate_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_g_t val) {
+    lsm6ds3tr_c_ctrl2_g_t ctrl2_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL2_G, (uint8_t*)&ctrl2_g, 1);
+
+    if(ret == 0) {
+        ctrl2_g.odr_g = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL2_G, (uint8_t*)&ctrl2_g, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Gyroscope data rate selection.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of odr_g in reg CTRL2_G
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_data_rate_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_g_t* val) {
+    lsm6ds3tr_c_ctrl2_g_t ctrl2_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL2_G, (uint8_t*)&ctrl2_g, 1);
+
+    switch(ctrl2_g.odr_g) {
+    case LSM6DS3TR_C_GY_ODR_OFF:
+        *val = LSM6DS3TR_C_GY_ODR_OFF;
+        break;
+
+    case LSM6DS3TR_C_GY_ODR_12Hz5:
+        *val = LSM6DS3TR_C_GY_ODR_12Hz5;
+        break;
+
+    case LSM6DS3TR_C_GY_ODR_26Hz:
+        *val = LSM6DS3TR_C_GY_ODR_26Hz;
+        break;
+
+    case LSM6DS3TR_C_GY_ODR_52Hz:
+        *val = LSM6DS3TR_C_GY_ODR_52Hz;
+        break;
+
+    case LSM6DS3TR_C_GY_ODR_104Hz:
+        *val = LSM6DS3TR_C_GY_ODR_104Hz;
+        break;
+
+    case LSM6DS3TR_C_GY_ODR_208Hz:
+        *val = LSM6DS3TR_C_GY_ODR_208Hz;
+        break;
+
+    case LSM6DS3TR_C_GY_ODR_416Hz:
+        *val = LSM6DS3TR_C_GY_ODR_416Hz;
+        break;
+
+    case LSM6DS3TR_C_GY_ODR_833Hz:
+        *val = LSM6DS3TR_C_GY_ODR_833Hz;
+        break;
+
+    case LSM6DS3TR_C_GY_ODR_1k66Hz:
+        *val = LSM6DS3TR_C_GY_ODR_1k66Hz;
+        break;
+
+    case LSM6DS3TR_C_GY_ODR_3k33Hz:
+        *val = LSM6DS3TR_C_GY_ODR_3k33Hz;
+        break;
+
+    case LSM6DS3TR_C_GY_ODR_6k66Hz:
+        *val = LSM6DS3TR_C_GY_ODR_6k66Hz;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_GY_ODR_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Block data update.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of bdu in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_block_data_update_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    if(ret == 0) {
+        ctrl3_c.bdu = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Block data update.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of bdu in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_block_data_update_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    *val = ctrl3_c.bdu;
+
+    return ret;
+}
+
+/**
+  * @brief  Weight of XL user offset bits of registers
+  *         X_OFS_USR(73h), Y_OFS_USR(74h), Z_OFS_USR(75h).[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of usr_off_w in reg CTRL6_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_offset_weight_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_usr_off_w_t val) {
+    lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+
+    if(ret == 0) {
+        ctrl6_c.usr_off_w = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Weight of XL user offset bits of registers
+  *         X_OFS_USR(73h), Y_OFS_USR(74h), Z_OFS_USR(75h).[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of usr_off_w in reg CTRL6_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_offset_weight_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_usr_off_w_t* val) {
+    lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+
+    switch(ctrl6_c.usr_off_w) {
+    case LSM6DS3TR_C_LSb_1mg:
+        *val = LSM6DS3TR_C_LSb_1mg;
+        break;
+
+    case LSM6DS3TR_C_LSb_16mg:
+        *val = LSM6DS3TR_C_LSb_16mg;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_WEIGHT_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  High-performance operating mode for accelerometer[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of xl_hm_mode in reg CTRL6_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_power_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_xl_hm_mode_t val) {
+    lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+
+    if(ret == 0) {
+        ctrl6_c.xl_hm_mode = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  High-performance operating mode for accelerometer.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of xl_hm_mode in reg CTRL6_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_power_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_xl_hm_mode_t* val) {
+    lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+
+    switch(ctrl6_c.xl_hm_mode) {
+    case LSM6DS3TR_C_XL_HIGH_PERFORMANCE:
+        *val = LSM6DS3TR_C_XL_HIGH_PERFORMANCE;
+        break;
+
+    case LSM6DS3TR_C_XL_NORMAL:
+        *val = LSM6DS3TR_C_XL_NORMAL;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_XL_PW_MODE_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Source register rounding function on WAKE_UP_SRC (1Bh),
+  *         TAP_SRC (1Ch), D6D_SRC (1Dh), STATUS_REG (1Eh) and
+  *         FUNC_SRC1 (53h) registers in the primary interface.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of rounding_status in reg CTRL7_G
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_rounding_on_status_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_rounding_status_t val) {
+    lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G, (uint8_t*)&ctrl7_g, 1);
+
+    if(ret == 0) {
+        ctrl7_g.rounding_status = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL7_G, (uint8_t*)&ctrl7_g, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Source register rounding function on WAKE_UP_SRC (1Bh),
+  *         TAP_SRC (1Ch), D6D_SRC (1Dh), STATUS_REG (1Eh) and
+  *         FUNC_SRC1 (53h) registers in the primary interface.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of rounding_status in reg CTRL7_G
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_rounding_on_status_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_rounding_status_t* val) {
+    lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G, (uint8_t*)&ctrl7_g, 1);
+
+    switch(ctrl7_g.rounding_status) {
+    case LSM6DS3TR_C_STAT_RND_DISABLE:
+        *val = LSM6DS3TR_C_STAT_RND_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_STAT_RND_ENABLE:
+        *val = LSM6DS3TR_C_STAT_RND_ENABLE;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_STAT_RND_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  High-performance operating mode disable for gyroscope.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of g_hm_mode in reg CTRL7_G
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_power_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_g_hm_mode_t val) {
+    lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G, (uint8_t*)&ctrl7_g, 1);
+
+    if(ret == 0) {
+        ctrl7_g.g_hm_mode = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL7_G, (uint8_t*)&ctrl7_g, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  High-performance operating mode disable for gyroscope.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of g_hm_mode in reg CTRL7_G
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_power_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_g_hm_mode_t* val) {
+    lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G, (uint8_t*)&ctrl7_g, 1);
+
+    switch(ctrl7_g.g_hm_mode) {
+    case LSM6DS3TR_C_GY_HIGH_PERFORMANCE:
+        *val = LSM6DS3TR_C_GY_HIGH_PERFORMANCE;
+        break;
+
+    case LSM6DS3TR_C_GY_NORMAL:
+        *val = LSM6DS3TR_C_GY_NORMAL;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_GY_PW_MODE_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Read all the interrupt/status flag of the device.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    WAKE_UP_SRC, TAP_SRC, D6D_SRC, STATUS_REG,
+  *                FUNC_SRC1, FUNC_SRC2, WRIST_TILT_IA, A_WRIST_TILT_Mask
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_all_sources_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_all_sources_t* val) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_SRC, (uint8_t*)&(val->wake_up_src), 1);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_SRC, (uint8_t*)&(val->tap_src), 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_D6D_SRC, (uint8_t*)&(val->d6d_src), 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STATUS_REG, (uint8_t*)&(val->status_reg), 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FUNC_SRC1, (uint8_t*)&(val->func_src1), 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FUNC_SRC2, (uint8_t*)&(val->func_src2), 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(
+            ctx, LSM6DS3TR_C_WRIST_TILT_IA, (uint8_t*)&(val->wrist_tilt_ia), 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(
+            ctx, LSM6DS3TR_C_A_WRIST_TILT_MASK, (uint8_t*)&(val->a_wrist_tilt_mask), 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+    }
+
+    return ret;
+}
+/**
+  * @brief  The STATUS_REG register is read by the primary interface[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Registers STATUS_REG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_status_reg_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_status_reg_t* val) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STATUS_REG, (uint8_t*)val, 1);
+
+    return ret;
+}
+
+/**
+  * @brief  Accelerometer new data available.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of xlda in reg STATUS_REG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_flag_data_ready_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_status_reg_t status_reg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STATUS_REG, (uint8_t*)&status_reg, 1);
+    *val = status_reg.xlda;
+
+    return ret;
+}
+
+/**
+  * @brief  Gyroscope new data available.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of gda in reg STATUS_REG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_flag_data_ready_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_status_reg_t status_reg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STATUS_REG, (uint8_t*)&status_reg, 1);
+    *val = status_reg.gda;
+
+    return ret;
+}
+
+/**
+  * @brief  Temperature new data available.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tda in reg STATUS_REG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_temp_flag_data_ready_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_status_reg_t status_reg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STATUS_REG, (uint8_t*)&status_reg, 1);
+    *val = status_reg.tda;
+
+    return ret;
+}
+
+/**
+  * @brief  Accelerometer axis user offset correction expressed in two’s
+  *         complement, weight depends on USR_OFF_W in CTRL6_C.
+  *         The value must be in the range [-127 127].[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that contains data to write
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_usr_offset_set(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_X_OFS_USR, buff, 3);
+
+    return ret;
+}
+
+/**
+  * @brief  Accelerometer axis user offset correction xpressed in two’s
+  *         complement, weight depends on USR_OFF_W in CTRL6_C.
+  *         The value must be in the range [-127 127].[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_usr_offset_get(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_X_OFS_USR, buff, 3);
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_Timestamp
+  * @brief       This section groups all the functions that manage the
+  *              timestamp generation.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Enable timestamp count. The count is saved in TIMESTAMP0_REG (40h),
+  *         TIMESTAMP1_REG (41h) and TIMESTAMP2_REG (42h).[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of timer_en in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_timestamp_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+
+    if(ret == 0) {
+        ctrl10_c.timer_en = val;
+
+        if(val != 0x00U) {
+            ctrl10_c.func_en = val;
+            ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable timestamp count. The count is saved in TIMESTAMP0_REG (40h),
+  *         TIMESTAMP1_REG (41h) and TIMESTAMP2_REG (42h).[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of timer_en in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_timestamp_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    *val = ctrl10_c.timer_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Timestamp register resolution setting.
+  *         Configuration of this bit affects
+  *         TIMESTAMP0_REG(40h), TIMESTAMP1_REG(41h),
+  *         TIMESTAMP2_REG(42h), STEP_TIMESTAMP_L(49h),
+  *         STEP_TIMESTAMP_H(4Ah) and
+  *         STEP_COUNT_DELTA(15h) registers.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of timer_hr in reg WAKE_UP_DUR
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_timestamp_res_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_timer_hr_t val) {
+    lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+
+    if(ret == 0) {
+        wake_up_dur.timer_hr = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Timestamp register resolution setting.
+  *         Configuration of this bit affects
+  *         TIMESTAMP0_REG(40h), TIMESTAMP1_REG(41h),
+  *         TIMESTAMP2_REG(42h), STEP_TIMESTAMP_L(49h),
+  *         STEP_TIMESTAMP_H(4Ah) and
+  *         STEP_COUNT_DELTA(15h) registers.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of timer_hr in reg WAKE_UP_DUR
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_timestamp_res_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_timer_hr_t* val) {
+    lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+
+    switch(wake_up_dur.timer_hr) {
+    case LSM6DS3TR_C_LSB_6ms4:
+        *val = LSM6DS3TR_C_LSB_6ms4;
+        break;
+
+    case LSM6DS3TR_C_LSB_25us:
+        *val = LSM6DS3TR_C_LSB_25us;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_TS_RES_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_Dataoutput
+  * @brief       This section groups all the data output functions.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Circular burst-mode (rounding) read from output registers
+  *         through the primary interface.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of rounding in reg CTRL5_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_rounding_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_rounding_t val) {
+    lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+
+    if(ret == 0) {
+        ctrl5_c.rounding = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Circular burst-mode (rounding) read from output registers
+  *         through the primary interface.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of rounding in reg CTRL5_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_rounding_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_rounding_t* val) {
+    lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+
+    switch(ctrl5_c.rounding) {
+    case LSM6DS3TR_C_ROUND_DISABLE:
+        *val = LSM6DS3TR_C_ROUND_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_ROUND_XL:
+        *val = LSM6DS3TR_C_ROUND_XL;
+        break;
+
+    case LSM6DS3TR_C_ROUND_GY:
+        *val = LSM6DS3TR_C_ROUND_GY;
+        break;
+
+    case LSM6DS3TR_C_ROUND_GY_XL:
+        *val = LSM6DS3TR_C_ROUND_GY_XL;
+        break;
+
+    case LSM6DS3TR_C_ROUND_SH1_TO_SH6:
+        *val = LSM6DS3TR_C_ROUND_SH1_TO_SH6;
+        break;
+
+    case LSM6DS3TR_C_ROUND_XL_SH1_TO_SH6:
+        *val = LSM6DS3TR_C_ROUND_XL_SH1_TO_SH6;
+        break;
+
+    case LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH12:
+        *val = LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH12;
+        break;
+
+    case LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH6:
+        *val = LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH6;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_ROUND_OUT_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Temperature data output register (r). L and H registers together
+  *         express a 16-bit word in two’s complement.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_temperature_raw_get(stmdev_ctx_t* ctx, int16_t* val) {
+    uint8_t buff[2];
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_OUT_TEMP_L, buff, 2);
+    *val = (int16_t)buff[1];
+    *val = (*val * 256) + (int16_t)buff[0];
+
+    return ret;
+}
+
+/**
+  * @brief  Angular rate sensor. The value is expressed as a 16-bit word in
+  *         two’s complement.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_angular_rate_raw_get(stmdev_ctx_t* ctx, int16_t* val) {
+    uint8_t buff[6];
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_OUTX_L_G, buff, 6);
+    val[0] = (int16_t)buff[1];
+    val[0] = (val[0] * 256) + (int16_t)buff[0];
+    val[1] = (int16_t)buff[3];
+    val[1] = (val[1] * 256) + (int16_t)buff[2];
+    val[2] = (int16_t)buff[5];
+    val[2] = (val[2] * 256) + (int16_t)buff[4];
+
+    return ret;
+}
+
+/**
+  * @brief  Linear acceleration output register. The value is expressed
+  *         as a 16-bit word in two’s complement.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_acceleration_raw_get(stmdev_ctx_t* ctx, int16_t* val) {
+    uint8_t buff[6];
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_OUTX_L_XL, buff, 6);
+    val[0] = (int16_t)buff[1];
+    val[0] = (val[0] * 256) + (int16_t)buff[0];
+    val[1] = (int16_t)buff[3];
+    val[1] = (val[1] * 256) + (int16_t)buff[2];
+    val[2] = (int16_t)buff[5];
+    val[2] = (val[2] * 256) + (int16_t)buff[4];
+
+    return ret;
+}
+
+/**
+  * @brief  External magnetometer raw data.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mag_calibrated_raw_get(stmdev_ctx_t* ctx, int16_t* val) {
+    uint8_t buff[6];
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_OUT_MAG_RAW_X_L, buff, 6);
+    val[0] = (int16_t)buff[1];
+    val[0] = (val[0] * 256) + (int16_t)buff[0];
+    val[1] = (int16_t)buff[3];
+    val[1] = (val[1] * 256) + (int16_t)buff[2];
+    val[2] = (int16_t)buff[5];
+    val[2] = (val[2] * 256) + (int16_t)buff[4];
+
+    return ret;
+}
+
+/**
+  * @brief  Read data in FIFO.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buffer Data buffer to store FIFO data.
+  * @param  len    Number of data to read from FIFO.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_raw_data_get(stmdev_ctx_t* ctx, uint8_t* buffer, uint8_t len) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_DATA_OUT_L, buffer, len);
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_common
+  * @brief       This section groups common useful functions.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Enable access to the embedded functions/sensor hub
+  *         configuration registers[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of func_cfg_en in reg FUNC_CFG_ACCESS
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mem_bank_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_func_cfg_en_t val) {
+    lsm6ds3tr_c_func_cfg_access_t func_cfg_access;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FUNC_CFG_ACCESS, (uint8_t*)&func_cfg_access, 1);
+
+    if(ret == 0) {
+        func_cfg_access.func_cfg_en = (uint8_t)val;
+        ret =
+            lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FUNC_CFG_ACCESS, (uint8_t*)&func_cfg_access, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable access to the embedded functions/sensor hub configuration
+  *         registers[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of func_cfg_en in reg FUNC_CFG_ACCESS
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mem_bank_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_func_cfg_en_t* val) {
+    lsm6ds3tr_c_func_cfg_access_t func_cfg_access;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FUNC_CFG_ACCESS, (uint8_t*)&func_cfg_access, 1);
+
+    switch(func_cfg_access.func_cfg_en) {
+    case LSM6DS3TR_C_USER_BANK:
+        *val = LSM6DS3TR_C_USER_BANK;
+        break;
+
+    case LSM6DS3TR_C_BANK_B:
+        *val = LSM6DS3TR_C_BANK_B;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_BANK_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Data-ready pulsed / letched mode[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of drdy_pulsed in reg DRDY_PULSE_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_data_ready_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_drdy_pulsed_g_t val) {
+    lsm6ds3tr_c_drdy_pulse_cfg_g_t drdy_pulse_cfg_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G, (uint8_t*)&drdy_pulse_cfg_g, 1);
+
+    if(ret == 0) {
+        drdy_pulse_cfg_g.drdy_pulsed = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(
+            ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G, (uint8_t*)&drdy_pulse_cfg_g, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Data-ready pulsed / letched mode[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of drdy_pulsed in reg DRDY_PULSE_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_data_ready_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_drdy_pulsed_g_t* val) {
+    lsm6ds3tr_c_drdy_pulse_cfg_g_t drdy_pulse_cfg_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G, (uint8_t*)&drdy_pulse_cfg_g, 1);
+
+    switch(drdy_pulse_cfg_g.drdy_pulsed) {
+    case LSM6DS3TR_C_DRDY_LATCHED:
+        *val = LSM6DS3TR_C_DRDY_LATCHED;
+        break;
+
+    case LSM6DS3TR_C_DRDY_PULSED:
+        *val = LSM6DS3TR_C_DRDY_PULSED;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_DRDY_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  DeviceWhoamI.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_device_id_get(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WHO_AM_I, buff, 1);
+
+    return ret;
+}
+
+/**
+  * @brief  Software reset. Restore the default values in user registers[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of sw_reset in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_reset_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    if(ret == 0) {
+        ctrl3_c.sw_reset = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Software reset. Restore the default values in user registers[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of sw_reset in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_reset_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    *val = ctrl3_c.sw_reset;
+
+    return ret;
+}
+
+/**
+  * @brief  Big/Little Endian Data selection.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of ble in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_data_format_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_ble_t val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    if(ret == 0) {
+        ctrl3_c.ble = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Big/Little Endian Data selection.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of ble in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_data_format_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_ble_t* val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    switch(ctrl3_c.ble) {
+    case LSM6DS3TR_C_LSB_AT_LOW_ADD:
+        *val = LSM6DS3TR_C_LSB_AT_LOW_ADD;
+        break;
+
+    case LSM6DS3TR_C_MSB_AT_LOW_ADD:
+        *val = LSM6DS3TR_C_MSB_AT_LOW_ADD;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_DATA_FMT_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Register address automatically incremented during a multiple byte
+  *         access with a serial interface.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of if_inc in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_auto_increment_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    if(ret == 0) {
+        ctrl3_c.if_inc = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Register address automatically incremented during a multiple byte
+  *         access with a serial interface.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of if_inc in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_auto_increment_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    *val = ctrl3_c.if_inc;
+
+    return ret;
+}
+
+/**
+  * @brief  Reboot memory content. Reload the calibration parameters.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of boot in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_boot_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    if(ret == 0) {
+        ctrl3_c.boot = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Reboot memory content. Reload the calibration parameters.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of boot in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_boot_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    *val = ctrl3_c.boot;
+
+    return ret;
+}
+
+/**
+  * @brief  Linear acceleration sensor self-test enable.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of st_xl in reg CTRL5_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_self_test_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_st_xl_t val) {
+    lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+
+    if(ret == 0) {
+        ctrl5_c.st_xl = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Linear acceleration sensor self-test enable.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of st_xl in reg CTRL5_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_self_test_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_st_xl_t* val) {
+    lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+
+    switch(ctrl5_c.st_xl) {
+    case LSM6DS3TR_C_XL_ST_DISABLE:
+        *val = LSM6DS3TR_C_XL_ST_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_XL_ST_POSITIVE:
+        *val = LSM6DS3TR_C_XL_ST_POSITIVE;
+        break;
+
+    case LSM6DS3TR_C_XL_ST_NEGATIVE:
+        *val = LSM6DS3TR_C_XL_ST_NEGATIVE;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_XL_ST_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Angular rate sensor self-test enable.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of st_g in reg CTRL5_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_self_test_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_st_g_t val) {
+    lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+
+    if(ret == 0) {
+        ctrl5_c.st_g = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Angular rate sensor self-test enable.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of st_g in reg CTRL5_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_self_test_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_st_g_t* val) {
+    lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+
+    switch(ctrl5_c.st_g) {
+    case LSM6DS3TR_C_GY_ST_DISABLE:
+        *val = LSM6DS3TR_C_GY_ST_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_GY_ST_POSITIVE:
+        *val = LSM6DS3TR_C_GY_ST_POSITIVE;
+        break;
+
+    case LSM6DS3TR_C_GY_ST_NEGATIVE:
+        *val = LSM6DS3TR_C_GY_ST_NEGATIVE;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_GY_ST_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_filters
+  * @brief       This section group all the functions concerning the filters
+  *              configuration that impact both accelerometer and gyro.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Mask DRDY on pin (both XL & Gyro) until filter settling ends
+  *         (XL and Gyro independently masked).[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of drdy_mask in reg CTRL4_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_filter_settling_mask_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+
+    if(ret == 0) {
+        ctrl4_c.drdy_mask = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Mask DRDY on pin (both XL & Gyro) until filter settling ends
+  *         (XL and Gyro independently masked).[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of drdy_mask in reg CTRL4_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_filter_settling_mask_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+    *val = ctrl4_c.drdy_mask;
+
+    return ret;
+}
+
+/**
+  * @brief  HPF or SLOPE filter selection on wake-up and Activity/Inactivity
+  *         functions.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of slope_fds in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_hp_path_internal_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_slope_fds_t val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+    if(ret == 0) {
+        tap_cfg.slope_fds = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  HPF or SLOPE filter selection on wake-up and Activity/Inactivity
+  *         functions.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of slope_fds in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_hp_path_internal_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_slope_fds_t* val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+    switch(tap_cfg.slope_fds) {
+    case LSM6DS3TR_C_USE_SLOPE:
+        *val = LSM6DS3TR_C_USE_SLOPE;
+        break;
+
+    case LSM6DS3TR_C_USE_HPF:
+        *val = LSM6DS3TR_C_USE_HPF;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_HP_PATH_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_accelerometer_filters
+  * @brief       This section group all the functions concerning the filters
+  *              configuration that impact accelerometer in every mode.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Accelerometer analog chain bandwidth selection (only for
+  *         accelerometer ODR ≥ 1.67 kHz).[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of bw0_xl in reg CTRL1_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_filter_analog_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_bw0_xl_t val) {
+    lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+
+    if(ret == 0) {
+        ctrl1_xl.bw0_xl = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Accelerometer analog chain bandwidth selection (only for
+  *         accelerometer ODR ≥ 1.67 kHz).[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of bw0_xl in reg CTRL1_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_filter_analog_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_bw0_xl_t* val) {
+    lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+
+    switch(ctrl1_xl.bw0_xl) {
+    case LSM6DS3TR_C_XL_ANA_BW_1k5Hz:
+        *val = LSM6DS3TR_C_XL_ANA_BW_1k5Hz;
+        break;
+
+    case LSM6DS3TR_C_XL_ANA_BW_400Hz:
+        *val = LSM6DS3TR_C_XL_ANA_BW_400Hz;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_XL_ANA_BW_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_accelerometer_filters
+  * @brief       This section group all the functions concerning the filters
+  *              configuration that impact accelerometer.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Accelerometer digital LPF (LPF1) bandwidth selection LPF2 is
+  *         not used.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of lpf1_bw_sel in reg CTRL1_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_lp1_bandwidth_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_lpf1_bw_sel_t val) {
+    lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+
+    if(ret == 0) {
+        ctrl1_xl.lpf1_bw_sel = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+
+            if(ret == 0) {
+                ctrl8_xl.lpf2_xl_en = 0;
+                ctrl8_xl.hp_slope_xl_en = 0;
+                ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Accelerometer digital LPF (LPF1) bandwidth selection LPF2
+  *         is not used.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of lpf1_bw_sel in reg CTRL1_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_lp1_bandwidth_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_lpf1_bw_sel_t* val) {
+    lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+
+    if(ret == 0) {
+        if((ctrl8_xl.lpf2_xl_en != 0x00U) || (ctrl8_xl.hp_slope_xl_en != 0x00U)) {
+            *val = LSM6DS3TR_C_XL_LP1_NA;
+        }
+
+        else {
+            ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL1_XL, (uint8_t*)&ctrl1_xl, 1);
+
+            switch(ctrl1_xl.lpf1_bw_sel) {
+            case LSM6DS3TR_C_XL_LP1_ODR_DIV_2:
+                *val = LSM6DS3TR_C_XL_LP1_ODR_DIV_2;
+                break;
+
+            case LSM6DS3TR_C_XL_LP1_ODR_DIV_4:
+                *val = LSM6DS3TR_C_XL_LP1_ODR_DIV_4;
+                break;
+
+            default:
+                *val = LSM6DS3TR_C_XL_LP1_NA;
+                break;
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  LPF2 on outputs[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of input_composite in reg CTRL8_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_lp2_bandwidth_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_input_composite_t val) {
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+
+    if(ret == 0) {
+        ctrl8_xl.input_composite = ((uint8_t)val & 0x10U) >> 4;
+        ctrl8_xl.hpcf_xl = (uint8_t)val & 0x03U;
+        ctrl8_xl.lpf2_xl_en = 1;
+        ctrl8_xl.hp_slope_xl_en = 0;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  LPF2 on outputs[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of input_composite in reg CTRL8_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_lp2_bandwidth_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_input_composite_t* val) {
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+
+    if(ret == 0) {
+        if((ctrl8_xl.lpf2_xl_en == 0x00U) || (ctrl8_xl.hp_slope_xl_en != 0x00U)) {
+            *val = LSM6DS3TR_C_XL_LP_NA;
+        }
+
+        else {
+            switch((ctrl8_xl.input_composite << 4) + ctrl8_xl.hpcf_xl) {
+            case LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_50:
+                *val = LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_50;
+                break;
+
+            case LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_100:
+                *val = LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_100;
+                break;
+
+            case LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_9:
+                *val = LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_9;
+                break;
+
+            case LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_400:
+                *val = LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_400;
+                break;
+
+            case LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_50:
+                *val = LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_50;
+                break;
+
+            case LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_100:
+                *val = LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_100;
+                break;
+
+            case LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_9:
+                *val = LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_9;
+                break;
+
+            case LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_400:
+                *val = LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_400;
+                break;
+
+            default:
+                *val = LSM6DS3TR_C_XL_LP_NA;
+                break;
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable HP filter reference mode.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of hp_ref_mode in reg CTRL8_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_reference_mode_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+
+    if(ret == 0) {
+        ctrl8_xl.hp_ref_mode = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable HP filter reference mode.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of hp_ref_mode in reg CTRL8_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_reference_mode_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+    *val = ctrl8_xl.hp_ref_mode;
+
+    return ret;
+}
+
+/**
+  * @brief  High pass/Slope on outputs.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of hpcf_xl in reg CTRL8_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_hp_bandwidth_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_hpcf_xl_t val) {
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+
+    if(ret == 0) {
+        ctrl8_xl.input_composite = 0;
+        ctrl8_xl.hpcf_xl = (uint8_t)val & 0x03U;
+        ctrl8_xl.hp_slope_xl_en = 1;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  High pass/Slope on outputs.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of hpcf_xl in reg CTRL8_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_xl_hp_bandwidth_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_hpcf_xl_t* val) {
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+
+    if(ctrl8_xl.hp_slope_xl_en == 0x00U) {
+        *val = LSM6DS3TR_C_XL_HP_NA;
+    }
+
+    switch(ctrl8_xl.hpcf_xl) {
+    case LSM6DS3TR_C_XL_HP_ODR_DIV_4:
+        *val = LSM6DS3TR_C_XL_HP_ODR_DIV_4;
+        break;
+
+    case LSM6DS3TR_C_XL_HP_ODR_DIV_100:
+        *val = LSM6DS3TR_C_XL_HP_ODR_DIV_100;
+        break;
+
+    case LSM6DS3TR_C_XL_HP_ODR_DIV_9:
+        *val = LSM6DS3TR_C_XL_HP_ODR_DIV_9;
+        break;
+
+    case LSM6DS3TR_C_XL_HP_ODR_DIV_400:
+        *val = LSM6DS3TR_C_XL_HP_ODR_DIV_400;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_XL_HP_NA;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_gyroscope_filters
+  * @brief       This section group all the functions concerning the filters
+  *              configuration that impact gyroscope.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Gyroscope low pass path bandwidth.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    gyroscope filtering chain configuration.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_band_pass_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_lpf1_sel_g_t val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
+    lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G, (uint8_t*)&ctrl7_g, 1);
+
+    if(ret == 0) {
+        ctrl7_g.hpm_g = ((uint8_t)val & 0x30U) >> 4;
+        ctrl7_g.hp_en_g = ((uint8_t)val & 0x80U) >> 7;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL7_G, (uint8_t*)&ctrl7_g, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+
+            if(ret == 0) {
+                ctrl6_c.ftype = (uint8_t)val & 0x03U;
+                ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+
+                if(ret == 0) {
+                    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+
+                    if(ret == 0) {
+                        ctrl4_c.lpf1_sel_g = ((uint8_t)val & 0x08U) >> 3;
+                        ret =
+                            lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+                    }
+                }
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Gyroscope low pass path bandwidth.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    gyroscope filtering chain
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_band_pass_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_lpf1_sel_g_t* val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
+    lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL7_G, (uint8_t*)&ctrl7_g, 1);
+
+            switch((ctrl7_g.hp_en_g << 7) + (ctrl7_g.hpm_g << 4) + (ctrl4_c.lpf1_sel_g << 3) +
+                   ctrl6_c.ftype) {
+            case LSM6DS3TR_C_HP_16mHz_LP2:
+                *val = LSM6DS3TR_C_HP_16mHz_LP2;
+                break;
+
+            case LSM6DS3TR_C_HP_65mHz_LP2:
+                *val = LSM6DS3TR_C_HP_65mHz_LP2;
+                break;
+
+            case LSM6DS3TR_C_HP_260mHz_LP2:
+                *val = LSM6DS3TR_C_HP_260mHz_LP2;
+                break;
+
+            case LSM6DS3TR_C_HP_1Hz04_LP2:
+                *val = LSM6DS3TR_C_HP_1Hz04_LP2;
+                break;
+
+            case LSM6DS3TR_C_HP_DISABLE_LP1_LIGHT:
+                *val = LSM6DS3TR_C_HP_DISABLE_LP1_LIGHT;
+                break;
+
+            case LSM6DS3TR_C_HP_DISABLE_LP1_NORMAL:
+                *val = LSM6DS3TR_C_HP_DISABLE_LP1_NORMAL;
+                break;
+
+            case LSM6DS3TR_C_HP_DISABLE_LP_STRONG:
+                *val = LSM6DS3TR_C_HP_DISABLE_LP_STRONG;
+                break;
+
+            case LSM6DS3TR_C_HP_DISABLE_LP1_AGGRESSIVE:
+                *val = LSM6DS3TR_C_HP_DISABLE_LP1_AGGRESSIVE;
+                break;
+
+            case LSM6DS3TR_C_HP_16mHz_LP1_LIGHT:
+                *val = LSM6DS3TR_C_HP_16mHz_LP1_LIGHT;
+                break;
+
+            case LSM6DS3TR_C_HP_65mHz_LP1_NORMAL:
+                *val = LSM6DS3TR_C_HP_65mHz_LP1_NORMAL;
+                break;
+
+            case LSM6DS3TR_C_HP_260mHz_LP1_STRONG:
+                *val = LSM6DS3TR_C_HP_260mHz_LP1_STRONG;
+                break;
+
+            case LSM6DS3TR_C_HP_1Hz04_LP1_AGGRESSIVE:
+                *val = LSM6DS3TR_C_HP_1Hz04_LP1_AGGRESSIVE;
+                break;
+
+            default:
+                *val = LSM6DS3TR_C_HP_GY_BAND_NA;
+                break;
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_serial_interface
+  * @brief       This section groups all the functions concerning serial
+  *              interface management
+  * @{
+  *
+  */
+
+/**
+  * @brief  SPI Serial Interface Mode selection.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of sim in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_spi_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_sim_t val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    if(ret == 0) {
+        ctrl3_c.sim = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  SPI Serial Interface Mode selection.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of sim in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_spi_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_sim_t* val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    switch(ctrl3_c.sim) {
+    case LSM6DS3TR_C_SPI_4_WIRE:
+        *val = LSM6DS3TR_C_SPI_4_WIRE;
+        break;
+
+    case LSM6DS3TR_C_SPI_3_WIRE:
+        *val = LSM6DS3TR_C_SPI_3_WIRE;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_SPI_MODE_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Disable / Enable I2C interface.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of i2c_disable in reg CTRL4_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_i2c_interface_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_i2c_disable_t val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+
+    if(ret == 0) {
+        ctrl4_c.i2c_disable = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Disable / Enable I2C interface.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of i2c_disable in reg CTRL4_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_i2c_interface_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_i2c_disable_t* val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+
+    switch(ctrl4_c.i2c_disable) {
+    case LSM6DS3TR_C_I2C_ENABLE:
+        *val = LSM6DS3TR_C_I2C_ENABLE;
+        break;
+
+    case LSM6DS3TR_C_I2C_DISABLE:
+        *val = LSM6DS3TR_C_I2C_DISABLE;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_I2C_MODE_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_interrupt_pins
+  * @brief       This section groups all the functions that manage
+  *              interrupt pins
+  * @{
+  *
+  */
+
+/**
+  * @brief  Select the signal that need to route on int1 pad[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    configure INT1_CTRL, MD1_CFG, CTRL4_C(den_drdy_int1),
+  *                MASTER_CONFIG(drdy_on_int1)
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pin_int1_route_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_int1_route_t val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    lsm6ds3tr_c_int1_ctrl_t int1_ctrl;
+    lsm6ds3tr_c_md1_cfg_t md1_cfg;
+    lsm6ds3tr_c_md2_cfg_t md2_cfg;
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT1_CTRL, (uint8_t*)&int1_ctrl, 1);
+
+    if(ret == 0) {
+        int1_ctrl.int1_drdy_xl = val.int1_drdy_xl;
+        int1_ctrl.int1_drdy_g = val.int1_drdy_g;
+        int1_ctrl.int1_boot = val.int1_boot;
+        int1_ctrl.int1_fth = val.int1_fth;
+        int1_ctrl.int1_fifo_ovr = val.int1_fifo_ovr;
+        int1_ctrl.int1_full_flag = val.int1_full_flag;
+        int1_ctrl.int1_sign_mot = val.int1_sign_mot;
+        int1_ctrl.int1_step_detector = val.int1_step_detector;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_INT1_CTRL, (uint8_t*)&int1_ctrl, 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD1_CFG, (uint8_t*)&md1_cfg, 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD2_CFG, (uint8_t*)&md2_cfg, 1);
+    }
+
+    if(ret == 0) {
+        md1_cfg.int1_timer = val.int1_timer;
+        md1_cfg.int1_tilt = val.int1_tilt;
+        md1_cfg.int1_6d = val.int1_6d;
+        md1_cfg.int1_double_tap = val.int1_double_tap;
+        md1_cfg.int1_ff = val.int1_ff;
+        md1_cfg.int1_wu = val.int1_wu;
+        md1_cfg.int1_single_tap = val.int1_single_tap;
+        md1_cfg.int1_inact_state = val.int1_inact_state;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MD1_CFG, (uint8_t*)&md1_cfg, 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+    }
+
+    if(ret == 0) {
+        ctrl4_c.den_drdy_int1 = val.den_drdy_int1;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    }
+
+    if(ret == 0) {
+        master_config.drdy_on_int1 = val.den_drdy_int1;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+        if((val.int1_6d != 0x00U) || (val.int1_ff != 0x00U) || (val.int1_wu != 0x00U) ||
+           (val.int1_single_tap != 0x00U) || (val.int1_double_tap != 0x00U) ||
+           (val.int1_inact_state != 0x00U) || (md2_cfg.int2_6d != 0x00U) ||
+           (md2_cfg.int2_ff != 0x00U) || (md2_cfg.int2_wu != 0x00U) ||
+           (md2_cfg.int2_single_tap != 0x00U) || (md2_cfg.int2_double_tap != 0x00U) ||
+           (md2_cfg.int2_inact_state != 0x00U)) {
+            tap_cfg.interrupts_enable = PROPERTY_ENABLE;
+        }
+
+        else {
+            tap_cfg.interrupts_enable = PROPERTY_DISABLE;
+        }
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Select the signal that need to route on int1 pad[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    read INT1_CTRL, MD1_CFG, CTRL4_C(den_drdy_int1),
+  *                MASTER_CONFIG(drdy_on_int1)
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pin_int1_route_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_int1_route_t* val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    lsm6ds3tr_c_int1_ctrl_t int1_ctrl;
+    lsm6ds3tr_c_md1_cfg_t md1_cfg;
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT1_CTRL, (uint8_t*)&int1_ctrl, 1);
+
+    if(ret == 0) {
+        val->int1_drdy_xl = int1_ctrl.int1_drdy_xl;
+        val->int1_drdy_g = int1_ctrl.int1_drdy_g;
+        val->int1_boot = int1_ctrl.int1_boot;
+        val->int1_fth = int1_ctrl.int1_fth;
+        val->int1_fifo_ovr = int1_ctrl.int1_fifo_ovr;
+        val->int1_full_flag = int1_ctrl.int1_full_flag;
+        val->int1_sign_mot = int1_ctrl.int1_sign_mot;
+        val->int1_step_detector = int1_ctrl.int1_step_detector;
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD1_CFG, (uint8_t*)&md1_cfg, 1);
+
+        if(ret == 0) {
+            val->int1_timer = md1_cfg.int1_timer;
+            val->int1_tilt = md1_cfg.int1_tilt;
+            val->int1_6d = md1_cfg.int1_6d;
+            val->int1_double_tap = md1_cfg.int1_double_tap;
+            val->int1_ff = md1_cfg.int1_ff;
+            val->int1_wu = md1_cfg.int1_wu;
+            val->int1_single_tap = md1_cfg.int1_single_tap;
+            val->int1_inact_state = md1_cfg.int1_inact_state;
+            ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+
+            if(ret == 0) {
+                val->den_drdy_int1 = ctrl4_c.den_drdy_int1;
+                ret = lsm6ds3tr_c_read_reg(
+                    ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+                val->den_drdy_int1 = master_config.drdy_on_int1;
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Select the signal that need to route on int2 pad[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    INT2_CTRL, DRDY_PULSE_CFG(int2_wrist_tilt), MD2_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pin_int2_route_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_int2_route_t val) {
+    lsm6ds3tr_c_int2_ctrl_t int2_ctrl;
+    lsm6ds3tr_c_md1_cfg_t md1_cfg;
+    lsm6ds3tr_c_md2_cfg_t md2_cfg;
+    lsm6ds3tr_c_drdy_pulse_cfg_g_t drdy_pulse_cfg_g;
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT2_CTRL, (uint8_t*)&int2_ctrl, 1);
+
+    if(ret == 0) {
+        int2_ctrl.int2_drdy_xl = val.int2_drdy_xl;
+        int2_ctrl.int2_drdy_g = val.int2_drdy_g;
+        int2_ctrl.int2_drdy_temp = val.int2_drdy_temp;
+        int2_ctrl.int2_fth = val.int2_fth;
+        int2_ctrl.int2_fifo_ovr = val.int2_fifo_ovr;
+        int2_ctrl.int2_full_flag = val.int2_full_flag;
+        int2_ctrl.int2_step_count_ov = val.int2_step_count_ov;
+        int2_ctrl.int2_step_delta = val.int2_step_delta;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_INT2_CTRL, (uint8_t*)&int2_ctrl, 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD1_CFG, (uint8_t*)&md1_cfg, 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD2_CFG, (uint8_t*)&md2_cfg, 1);
+    }
+
+    if(ret == 0) {
+        md2_cfg.int2_iron = val.int2_iron;
+        md2_cfg.int2_tilt = val.int2_tilt;
+        md2_cfg.int2_6d = val.int2_6d;
+        md2_cfg.int2_double_tap = val.int2_double_tap;
+        md2_cfg.int2_ff = val.int2_ff;
+        md2_cfg.int2_wu = val.int2_wu;
+        md2_cfg.int2_single_tap = val.int2_single_tap;
+        md2_cfg.int2_inact_state = val.int2_inact_state;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MD2_CFG, (uint8_t*)&md2_cfg, 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(
+            ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G, (uint8_t*)&drdy_pulse_cfg_g, 1);
+    }
+
+    if(ret == 0) {
+        drdy_pulse_cfg_g.int2_wrist_tilt = val.int2_wrist_tilt;
+        ret = lsm6ds3tr_c_write_reg(
+            ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G, (uint8_t*)&drdy_pulse_cfg_g, 1);
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+        if((md1_cfg.int1_6d != 0x00U) || (md1_cfg.int1_ff != 0x00U) ||
+           (md1_cfg.int1_wu != 0x00U) || (md1_cfg.int1_single_tap != 0x00U) ||
+           (md1_cfg.int1_double_tap != 0x00U) || (md1_cfg.int1_inact_state != 0x00U) ||
+           (val.int2_6d != 0x00U) || (val.int2_ff != 0x00U) || (val.int2_wu != 0x00U) ||
+           (val.int2_single_tap != 0x00U) || (val.int2_double_tap != 0x00U) ||
+           (val.int2_inact_state != 0x00U)) {
+            tap_cfg.interrupts_enable = PROPERTY_ENABLE;
+        }
+
+        else {
+            tap_cfg.interrupts_enable = PROPERTY_DISABLE;
+        }
+    }
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Select the signal that need to route on int2 pad[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    INT2_CTRL, DRDY_PULSE_CFG(int2_wrist_tilt), MD2_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pin_int2_route_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_int2_route_t* val) {
+    lsm6ds3tr_c_int2_ctrl_t int2_ctrl;
+    lsm6ds3tr_c_md2_cfg_t md2_cfg;
+    lsm6ds3tr_c_drdy_pulse_cfg_g_t drdy_pulse_cfg_g;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT2_CTRL, (uint8_t*)&int2_ctrl, 1);
+
+    if(ret == 0) {
+        val->int2_drdy_xl = int2_ctrl.int2_drdy_xl;
+        val->int2_drdy_g = int2_ctrl.int2_drdy_g;
+        val->int2_drdy_temp = int2_ctrl.int2_drdy_temp;
+        val->int2_fth = int2_ctrl.int2_fth;
+        val->int2_fifo_ovr = int2_ctrl.int2_fifo_ovr;
+        val->int2_full_flag = int2_ctrl.int2_full_flag;
+        val->int2_step_count_ov = int2_ctrl.int2_step_count_ov;
+        val->int2_step_delta = int2_ctrl.int2_step_delta;
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MD2_CFG, (uint8_t*)&md2_cfg, 1);
+
+        if(ret == 0) {
+            val->int2_iron = md2_cfg.int2_iron;
+            val->int2_tilt = md2_cfg.int2_tilt;
+            val->int2_6d = md2_cfg.int2_6d;
+            val->int2_double_tap = md2_cfg.int2_double_tap;
+            val->int2_ff = md2_cfg.int2_ff;
+            val->int2_wu = md2_cfg.int2_wu;
+            val->int2_single_tap = md2_cfg.int2_single_tap;
+            val->int2_inact_state = md2_cfg.int2_inact_state;
+            ret = lsm6ds3tr_c_read_reg(
+                ctx, LSM6DS3TR_C_DRDY_PULSE_CFG_G, (uint8_t*)&drdy_pulse_cfg_g, 1);
+            val->int2_wrist_tilt = drdy_pulse_cfg_g.int2_wrist_tilt;
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Push-pull/open drain selection on interrupt pads.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of pp_od in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pin_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_pp_od_t val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    if(ret == 0) {
+        ctrl3_c.pp_od = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Push-pull/open drain selection on interrupt pads.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of pp_od in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pin_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_pp_od_t* val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    switch(ctrl3_c.pp_od) {
+    case LSM6DS3TR_C_PUSH_PULL:
+        *val = LSM6DS3TR_C_PUSH_PULL;
+        break;
+
+    case LSM6DS3TR_C_OPEN_DRAIN:
+        *val = LSM6DS3TR_C_OPEN_DRAIN;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_PIN_MODE_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Interrupt active-high/low.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of h_lactive in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pin_polarity_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_h_lactive_t val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    if(ret == 0) {
+        ctrl3_c.h_lactive = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Interrupt active-high/low.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of h_lactive in reg CTRL3_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pin_polarity_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_h_lactive_t* val) {
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL3_C, (uint8_t*)&ctrl3_c, 1);
+
+    switch(ctrl3_c.h_lactive) {
+    case LSM6DS3TR_C_ACTIVE_HIGH:
+        *val = LSM6DS3TR_C_ACTIVE_HIGH;
+        break;
+
+    case LSM6DS3TR_C_ACTIVE_LOW:
+        *val = LSM6DS3TR_C_ACTIVE_LOW;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_POLARITY_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  All interrupt signals become available on INT1 pin.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of int2_on_int1 in reg CTRL4_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_all_on_int1_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+
+    if(ret == 0) {
+        ctrl4_c.int2_on_int1 = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  All interrupt signals become available on INT1 pin.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of int2_on_int1 in reg CTRL4_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_all_on_int1_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+    *val = ctrl4_c.int2_on_int1;
+
+    return ret;
+}
+
+/**
+  * @brief  Latched/pulsed interrupt.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of lir in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_int_notification_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_lir_t val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+    if(ret == 0) {
+        tap_cfg.lir = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Latched/pulsed interrupt.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of lir in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_int_notification_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_lir_t* val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+    switch(tap_cfg.lir) {
+    case LSM6DS3TR_C_INT_PULSED:
+        *val = LSM6DS3TR_C_INT_PULSED;
+        break;
+
+    case LSM6DS3TR_C_INT_LATCHED:
+        *val = LSM6DS3TR_C_INT_LATCHED;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_INT_MODE;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_Wake_Up_event
+  * @brief       This section groups all the functions that manage the
+  *              Wake Up event generation.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Threshold for wakeup.1 LSB = FS_XL / 64.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of wk_ths in reg WAKE_UP_THS
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_wkup_threshold_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_wake_up_ths_t wake_up_ths;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS, (uint8_t*)&wake_up_ths, 1);
+
+    if(ret == 0) {
+        wake_up_ths.wk_ths = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS, (uint8_t*)&wake_up_ths, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Threshold for wakeup.1 LSB = FS_XL / 64.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of wk_ths in reg WAKE_UP_THS
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_wkup_threshold_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_wake_up_ths_t wake_up_ths;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS, (uint8_t*)&wake_up_ths, 1);
+    *val = wake_up_ths.wk_ths;
+
+    return ret;
+}
+
+/**
+  * @brief  Wake up duration event.1LSb = 1 / ODR[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of wake_dur in reg WAKE_UP_DUR
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_wkup_dur_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+
+    if(ret == 0) {
+        wake_up_dur.wake_dur = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Wake up duration event.1LSb = 1 / ODR[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of wake_dur in reg WAKE_UP_DUR
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_wkup_dur_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+    *val = wake_up_dur.wake_dur;
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_Activity/Inactivity_detection
+  * @brief       This section groups all the functions concerning
+  *              activity/inactivity detection.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Enables gyroscope Sleep mode.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of sleep in reg CTRL4_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_sleep_mode_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+
+    if(ret == 0) {
+        ctrl4_c.sleep = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enables gyroscope Sleep mode.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of sleep in reg CTRL4_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_gy_sleep_mode_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+    *val = ctrl4_c.sleep;
+
+    return ret;
+}
+
+/**
+  * @brief  Enable inactivity function.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of inact_en in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_act_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_inact_en_t val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+    if(ret == 0) {
+        tap_cfg.inact_en = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable inactivity function.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of inact_en in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_act_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_inact_en_t* val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+    switch(tap_cfg.inact_en) {
+    case LSM6DS3TR_C_PROPERTY_DISABLE:
+        *val = LSM6DS3TR_C_PROPERTY_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_XL_12Hz5_GY_NOT_AFFECTED:
+        *val = LSM6DS3TR_C_XL_12Hz5_GY_NOT_AFFECTED;
+        break;
+
+    case LSM6DS3TR_C_XL_12Hz5_GY_SLEEP:
+        *val = LSM6DS3TR_C_XL_12Hz5_GY_SLEEP;
+        break;
+
+    case LSM6DS3TR_C_XL_12Hz5_GY_PD:
+        *val = LSM6DS3TR_C_XL_12Hz5_GY_PD;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_ACT_MODE_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Duration to go in sleep mode.1 LSb = 512 / ODR[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of sleep_dur in reg WAKE_UP_DUR
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_act_sleep_dur_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+
+    if(ret == 0) {
+        wake_up_dur.sleep_dur = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Duration to go in sleep mode. 1 LSb = 512 / ODR[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of sleep_dur in reg WAKE_UP_DUR
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_act_sleep_dur_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+    *val = wake_up_dur.sleep_dur;
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_tap_generator
+  * @brief       This section groups all the functions that manage the
+  *              tap and double tap event generation.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Read the tap / double tap source register.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Structure of registers from TAP_SRC
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_src_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_tap_src_t* val) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_SRC, (uint8_t*)val, 1);
+
+    return ret;
+}
+
+/**
+  * @brief  Enable Z direction in tap recognition.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tap_z_en in reg TAP_CFG
+  *
+  */
+int32_t lsm6ds3tr_c_tap_detection_on_z_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+    if(ret == 0) {
+        tap_cfg.tap_z_en = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable Z direction in tap recognition.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tap_z_en in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_detection_on_z_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    *val = tap_cfg.tap_z_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Enable Y direction in tap recognition.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tap_y_en in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_detection_on_y_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+    if(ret == 0) {
+        tap_cfg.tap_y_en = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable Y direction in tap recognition.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tap_y_en in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_detection_on_y_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    *val = tap_cfg.tap_y_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Enable X direction in tap recognition.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tap_x_en in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_detection_on_x_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+
+    if(ret == 0) {
+        tap_cfg.tap_x_en = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable X direction in tap recognition.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tap_x_en in reg TAP_CFG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_detection_on_x_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_CFG, (uint8_t*)&tap_cfg, 1);
+    *val = tap_cfg.tap_x_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Threshold for tap recognition.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tap_ths in reg TAP_THS_6D
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_threshold_x_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D, (uint8_t*)&tap_ths_6d, 1);
+
+    if(ret == 0) {
+        tap_ths_6d.tap_ths = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_THS_6D, (uint8_t*)&tap_ths_6d, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Threshold for tap recognition.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tap_ths in reg TAP_THS_6D
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_threshold_x_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D, (uint8_t*)&tap_ths_6d, 1);
+    *val = tap_ths_6d.tap_ths;
+
+    return ret;
+}
+
+/**
+  * @brief  Maximum duration is the maximum time of an overthreshold signal
+  *         detection to be recognized as a tap event.
+  *         The default value of these bits is 00b which corresponds to
+  *         4*ODR_XL time.
+  *         If the SHOCK[1:0] bits are set to a different
+  *         value, 1LSB corresponds to 8*ODR_XL time.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of shock in reg INT_DUR2
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_shock_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_int_dur2_t int_dur2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2, (uint8_t*)&int_dur2, 1);
+
+    if(ret == 0) {
+        int_dur2.shock = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_INT_DUR2, (uint8_t*)&int_dur2, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Maximum duration is the maximum time of an overthreshold signal
+  *         detection to be recognized as a tap event.
+  *         The default value of these bits is 00b which corresponds to
+  *         4*ODR_XL time.
+  *         If the SHOCK[1:0] bits are set to a different value, 1LSB
+  *         corresponds to 8*ODR_XL time.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of shock in reg INT_DUR2
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_shock_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_int_dur2_t int_dur2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2, (uint8_t*)&int_dur2, 1);
+    *val = int_dur2.shock;
+
+    return ret;
+}
+
+/**
+  * @brief  Quiet time is the time after the first detected tap in which there
+  *         must not be any overthreshold event.
+  *         The default value of these bits is 00b which corresponds to
+  *         2*ODR_XL time.
+  *         If the QUIET[1:0] bits are set to a different value, 1LSB
+  *         corresponds to 4*ODR_XL time.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of quiet in reg INT_DUR2
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_quiet_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_int_dur2_t int_dur2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2, (uint8_t*)&int_dur2, 1);
+
+    if(ret == 0) {
+        int_dur2.quiet = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_INT_DUR2, (uint8_t*)&int_dur2, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Quiet time is the time after the first detected tap in which there
+  *         must not be any overthreshold event.
+  *         The default value of these bits is 00b which corresponds to
+  *         2*ODR_XL time.
+  *         If the QUIET[1:0] bits are set to a different value, 1LSB
+  *         corresponds to 4*ODR_XL time.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of quiet in reg INT_DUR2
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_quiet_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_int_dur2_t int_dur2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2, (uint8_t*)&int_dur2, 1);
+    *val = int_dur2.quiet;
+
+    return ret;
+}
+
+/**
+  * @brief  When double tap recognition is enabled, this register expresses the
+  *         maximum time between two consecutive detected taps to determine a
+  *         double tap event.
+  *         The default value of these bits is 0000b which corresponds to
+  *         16*ODR_XL time.
+  *         If the DUR[3:0] bits are set to a different value,1LSB corresponds
+  *         to 32*ODR_XL time.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of dur in reg INT_DUR2
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_dur_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_int_dur2_t int_dur2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2, (uint8_t*)&int_dur2, 1);
+
+    if(ret == 0) {
+        int_dur2.dur = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_INT_DUR2, (uint8_t*)&int_dur2, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  When double tap recognition is enabled, this register expresses the
+  *         maximum time between two consecutive detected taps to determine a
+  *         double tap event.
+  *         The default value of these bits is 0000b which corresponds to
+  *         16*ODR_XL time.
+  *         If the DUR[3:0] bits are set to a different value,1LSB corresponds
+  *         to 32*ODR_XL time.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of dur in reg INT_DUR2
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_dur_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_int_dur2_t int_dur2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_INT_DUR2, (uint8_t*)&int_dur2, 1);
+    *val = int_dur2.dur;
+
+    return ret;
+}
+
+/**
+  * @brief  Single/double-tap event enable/disable.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of
+  *                                      single_double_tap in reg WAKE_UP_THS
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_single_double_tap_t val) {
+    lsm6ds3tr_c_wake_up_ths_t wake_up_ths;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS, (uint8_t*)&wake_up_ths, 1);
+
+    if(ret == 0) {
+        wake_up_ths.single_double_tap = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS, (uint8_t*)&wake_up_ths, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Single/double-tap event enable/disable.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of single_double_tap
+  *                                      in reg WAKE_UP_THS
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tap_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_single_double_tap_t* val) {
+    lsm6ds3tr_c_wake_up_ths_t wake_up_ths;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_THS, (uint8_t*)&wake_up_ths, 1);
+
+    switch(wake_up_ths.single_double_tap) {
+    case LSM6DS3TR_C_ONLY_SINGLE:
+        *val = LSM6DS3TR_C_ONLY_SINGLE;
+        break;
+
+    case LSM6DS3TR_C_BOTH_SINGLE_DOUBLE:
+        *val = LSM6DS3TR_C_BOTH_SINGLE_DOUBLE;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_TAP_MODE_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_ Six_position_detection(6D/4D)
+  * @brief       This section groups all the functions concerning six
+  *              position detection (6D).
+  * @{
+  *
+  */
+
+/**
+  * @brief  LPF2 feed 6D function selection.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of low_pass_on_6d in
+  *                                   reg CTRL8_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_6d_feed_data_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_low_pass_on_6d_t val) {
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+
+    if(ret == 0) {
+        ctrl8_xl.low_pass_on_6d = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  LPF2 feed 6D function selection.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of low_pass_on_6d in reg CTRL8_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_6d_feed_data_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_low_pass_on_6d_t* val) {
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL8_XL, (uint8_t*)&ctrl8_xl, 1);
+
+    switch(ctrl8_xl.low_pass_on_6d) {
+    case LSM6DS3TR_C_ODR_DIV_2_FEED:
+        *val = LSM6DS3TR_C_ODR_DIV_2_FEED;
+        break;
+
+    case LSM6DS3TR_C_LPF2_FEED:
+        *val = LSM6DS3TR_C_LPF2_FEED;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_6D_FEED_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Threshold for 4D/6D function.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of sixd_ths in reg TAP_THS_6D
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_6d_threshold_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_sixd_ths_t val) {
+    lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D, (uint8_t*)&tap_ths_6d, 1);
+
+    if(ret == 0) {
+        tap_ths_6d.sixd_ths = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_THS_6D, (uint8_t*)&tap_ths_6d, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Threshold for 4D/6D function.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of sixd_ths in reg TAP_THS_6D
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_6d_threshold_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_sixd_ths_t* val) {
+    lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D, (uint8_t*)&tap_ths_6d, 1);
+
+    switch(tap_ths_6d.sixd_ths) {
+    case LSM6DS3TR_C_DEG_80:
+        *val = LSM6DS3TR_C_DEG_80;
+        break;
+
+    case LSM6DS3TR_C_DEG_70:
+        *val = LSM6DS3TR_C_DEG_70;
+        break;
+
+    case LSM6DS3TR_C_DEG_60:
+        *val = LSM6DS3TR_C_DEG_60;
+        break;
+
+    case LSM6DS3TR_C_DEG_50:
+        *val = LSM6DS3TR_C_DEG_50;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_6D_TH_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  4D orientation detection enable.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of d4d_en in reg TAP_THS_6D
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_4d_mode_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D, (uint8_t*)&tap_ths_6d, 1);
+
+    if(ret == 0) {
+        tap_ths_6d.d4d_en = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_TAP_THS_6D, (uint8_t*)&tap_ths_6d, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  4D orientation detection enable.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of d4d_en in reg TAP_THS_6D
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_4d_mode_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_TAP_THS_6D, (uint8_t*)&tap_ths_6d, 1);
+    *val = tap_ths_6d.d4d_en;
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_free_fall
+  * @brief       This section group all the functions concerning the free
+  *              fall detection.
+  * @{
+  *
+  */
+
+/**
+  * @brief Free-fall duration event. 1LSb = 1 / ODR[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of ff_dur in reg WAKE_UP_DUR
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_ff_dur_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
+    lsm6ds3tr_c_free_fall_t free_fall;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FREE_FALL, (uint8_t*)&free_fall, 1);
+
+    if(ret == 0) {
+        free_fall.ff_dur = (val & 0x1FU);
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FREE_FALL, (uint8_t*)&free_fall, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+
+            if(ret == 0) {
+                wake_up_dur.ff_dur = (val & 0x20U) >> 5;
+                ret =
+                    lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Free-fall duration event. 1LSb = 1 / ODR[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of ff_dur in reg WAKE_UP_DUR
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_ff_dur_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
+    lsm6ds3tr_c_free_fall_t free_fall;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_WAKE_UP_DUR, (uint8_t*)&wake_up_dur, 1);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FREE_FALL, (uint8_t*)&free_fall, 1);
+    }
+
+    *val = (wake_up_dur.ff_dur << 5) + free_fall.ff_dur;
+
+    return ret;
+}
+
+/**
+  * @brief  Free fall threshold setting.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of ff_ths in reg FREE_FALL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_ff_threshold_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_ff_ths_t val) {
+    lsm6ds3tr_c_free_fall_t free_fall;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FREE_FALL, (uint8_t*)&free_fall, 1);
+
+    if(ret == 0) {
+        free_fall.ff_ths = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FREE_FALL, (uint8_t*)&free_fall, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Free fall threshold setting.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of ff_ths in reg FREE_FALL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_ff_threshold_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_ff_ths_t* val) {
+    lsm6ds3tr_c_free_fall_t free_fall;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FREE_FALL, (uint8_t*)&free_fall, 1);
+
+    switch(free_fall.ff_ths) {
+    case LSM6DS3TR_C_FF_TSH_156mg:
+        *val = LSM6DS3TR_C_FF_TSH_156mg;
+        break;
+
+    case LSM6DS3TR_C_FF_TSH_219mg:
+        *val = LSM6DS3TR_C_FF_TSH_219mg;
+        break;
+
+    case LSM6DS3TR_C_FF_TSH_250mg:
+        *val = LSM6DS3TR_C_FF_TSH_250mg;
+        break;
+
+    case LSM6DS3TR_C_FF_TSH_312mg:
+        *val = LSM6DS3TR_C_FF_TSH_312mg;
+        break;
+
+    case LSM6DS3TR_C_FF_TSH_344mg:
+        *val = LSM6DS3TR_C_FF_TSH_344mg;
+        break;
+
+    case LSM6DS3TR_C_FF_TSH_406mg:
+        *val = LSM6DS3TR_C_FF_TSH_406mg;
+        break;
+
+    case LSM6DS3TR_C_FF_TSH_469mg:
+        *val = LSM6DS3TR_C_FF_TSH_469mg;
+        break;
+
+    case LSM6DS3TR_C_FF_TSH_500mg:
+        *val = LSM6DS3TR_C_FF_TSH_500mg;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_FF_TSH_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_fifo
+  * @brief       This section group all the functions concerning the
+  *              fifo usage
+  * @{
+  *
+  */
+
+/**
+  * @brief  FIFO watermark level selection.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of fth in reg FIFO_CTRL1
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_watermark_set(stmdev_ctx_t* ctx, uint16_t val) {
+    lsm6ds3tr_c_fifo_ctrl1_t fifo_ctrl1;
+    lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+
+    if(ret == 0) {
+        fifo_ctrl1.fth = (uint8_t)(0x00FFU & val);
+        fifo_ctrl2.fth = (uint8_t)((0x0700U & val) >> 8);
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL1, (uint8_t*)&fifo_ctrl1, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  FIFO watermark level selection.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of fth in reg FIFO_CTRL1
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_watermark_get(stmdev_ctx_t* ctx, uint16_t* val) {
+    lsm6ds3tr_c_fifo_ctrl1_t fifo_ctrl1;
+    lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL1, (uint8_t*)&fifo_ctrl1, 1);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+    }
+
+    *val = ((uint16_t)fifo_ctrl2.fth << 8) + (uint16_t)fifo_ctrl1.fth;
+
+    return ret;
+}
+
+/**
+  * @brief  FIFO data level.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    get the values of diff_fifo in reg  FIFO_STATUS1 and
+  *                FIFO_STATUS2(diff_fifo), it is recommended to set the
+  *                BDU bit.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_data_level_get(stmdev_ctx_t* ctx, uint16_t* val) {
+    lsm6ds3tr_c_fifo_status1_t fifo_status1;
+    lsm6ds3tr_c_fifo_status2_t fifo_status2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_STATUS1, (uint8_t*)&fifo_status1, 1);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_STATUS2, (uint8_t*)&fifo_status2, 1);
+        *val = ((uint16_t)fifo_status2.diff_fifo << 8) + (uint16_t)fifo_status1.diff_fifo;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  FIFO watermark.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    get the values of watermark in reg  FIFO_STATUS2 and
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_wtm_flag_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_fifo_status2_t fifo_status2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_STATUS2, (uint8_t*)&fifo_status2, 1);
+    *val = fifo_status2.waterm;
+
+    return ret;
+}
+
+/**
+  * @brief  FIFO pattern.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    get the values of fifo_pattern in reg  FIFO_STATUS3 and
+  *                FIFO_STATUS4, it is recommended to set the BDU bit
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_pattern_get(stmdev_ctx_t* ctx, uint16_t* val) {
+    lsm6ds3tr_c_fifo_status3_t fifo_status3;
+    lsm6ds3tr_c_fifo_status4_t fifo_status4;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_STATUS3, (uint8_t*)&fifo_status3, 1);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_STATUS4, (uint8_t*)&fifo_status4, 1);
+        *val = ((uint16_t)fifo_status4.fifo_pattern << 8) + fifo_status3.fifo_pattern;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Batching of temperature data[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of fifo_temp_en in reg FIFO_CTRL2
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_temp_batch_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+
+    if(ret == 0) {
+        fifo_ctrl2.fifo_temp_en = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Batching of temperature data[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of fifo_temp_en in reg FIFO_CTRL2
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_temp_batch_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+    *val = fifo_ctrl2.fifo_temp_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Trigger signal for FIFO write operation.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    act on FIFO_CTRL2(timer_pedo_fifo_drdy)
+  *                and MASTER_CONFIG(data_valid_sel_fifo)
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_write_trigger_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_trigger_fifo_t val) {
+    lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+
+    if(ret == 0) {
+        fifo_ctrl2.timer_pedo_fifo_drdy = (uint8_t)val & 0x01U;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+
+        if(ret == 0) {
+            ret =
+                lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+            if(ret == 0) {
+                master_config.data_valid_sel_fifo = (((uint8_t)val & 0x02U) >> 1);
+                ret = lsm6ds3tr_c_write_reg(
+                    ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Trigger signal for FIFO write operation.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    act on FIFO_CTRL2(timer_pedo_fifo_drdy)
+  *                and MASTER_CONFIG(data_valid_sel_fifo)
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_write_trigger_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_trigger_fifo_t* val) {
+    lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+        switch((fifo_ctrl2.timer_pedo_fifo_drdy << 1) + fifo_ctrl2.timer_pedo_fifo_drdy) {
+        case LSM6DS3TR_C_TRG_XL_GY_DRDY:
+            *val = LSM6DS3TR_C_TRG_XL_GY_DRDY;
+            break;
+
+        case LSM6DS3TR_C_TRG_STEP_DETECT:
+            *val = LSM6DS3TR_C_TRG_STEP_DETECT;
+            break;
+
+        case LSM6DS3TR_C_TRG_SH_DRDY:
+            *val = LSM6DS3TR_C_TRG_SH_DRDY;
+            break;
+
+        default:
+            *val = LSM6DS3TR_C_TRG_SH_ND;
+            break;
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief   Enable pedometer step counter and timestamp as 4th
+  *          FIFO data set.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of timer_pedo_fifo_en in reg FIFO_CTRL2
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_pedo_and_timestamp_batch_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+
+    if(ret == 0) {
+        fifo_ctrl2.timer_pedo_fifo_en = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable pedometer step counter and timestamp as 4th
+  *         FIFO data set.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of timer_pedo_fifo_en in reg FIFO_CTRL2
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_pedo_and_timestamp_batch_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL2, (uint8_t*)&fifo_ctrl2, 1);
+    *val = fifo_ctrl2.timer_pedo_fifo_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Selects Batching Data Rate (writing frequency in FIFO) for
+  *         accelerometer data.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of dec_fifo_xl in reg FIFO_CTRL3
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_xl_batch_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_fifo_xl_t val) {
+    lsm6ds3tr_c_fifo_ctrl3_t fifo_ctrl3;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3, (uint8_t*)&fifo_ctrl3, 1);
+
+    if(ret == 0) {
+        fifo_ctrl3.dec_fifo_xl = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3, (uint8_t*)&fifo_ctrl3, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Selects Batching Data Rate (writing frequency in FIFO) for
+  *         accelerometer data.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of dec_fifo_xl in reg FIFO_CTRL3
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_xl_batch_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_fifo_xl_t* val) {
+    lsm6ds3tr_c_fifo_ctrl3_t fifo_ctrl3;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3, (uint8_t*)&fifo_ctrl3, 1);
+
+    switch(fifo_ctrl3.dec_fifo_xl) {
+    case LSM6DS3TR_C_FIFO_XL_DISABLE:
+        *val = LSM6DS3TR_C_FIFO_XL_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_FIFO_XL_NO_DEC:
+        *val = LSM6DS3TR_C_FIFO_XL_NO_DEC;
+        break;
+
+    case LSM6DS3TR_C_FIFO_XL_DEC_2:
+        *val = LSM6DS3TR_C_FIFO_XL_DEC_2;
+        break;
+
+    case LSM6DS3TR_C_FIFO_XL_DEC_3:
+        *val = LSM6DS3TR_C_FIFO_XL_DEC_3;
+        break;
+
+    case LSM6DS3TR_C_FIFO_XL_DEC_4:
+        *val = LSM6DS3TR_C_FIFO_XL_DEC_4;
+        break;
+
+    case LSM6DS3TR_C_FIFO_XL_DEC_8:
+        *val = LSM6DS3TR_C_FIFO_XL_DEC_8;
+        break;
+
+    case LSM6DS3TR_C_FIFO_XL_DEC_16:
+        *val = LSM6DS3TR_C_FIFO_XL_DEC_16;
+        break;
+
+    case LSM6DS3TR_C_FIFO_XL_DEC_32:
+        *val = LSM6DS3TR_C_FIFO_XL_DEC_32;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_FIFO_XL_DEC_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Selects Batching Data Rate (writing frequency in FIFO)
+  *         for gyroscope data.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of dec_fifo_gyro in reg FIFO_CTRL3
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_gy_batch_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_fifo_gyro_t val) {
+    lsm6ds3tr_c_fifo_ctrl3_t fifo_ctrl3;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3, (uint8_t*)&fifo_ctrl3, 1);
+
+    if(ret == 0) {
+        fifo_ctrl3.dec_fifo_gyro = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3, (uint8_t*)&fifo_ctrl3, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Selects Batching Data Rate (writing frequency in FIFO)
+  *         for gyroscope data.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of dec_fifo_gyro in reg FIFO_CTRL3
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_gy_batch_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_fifo_gyro_t* val) {
+    lsm6ds3tr_c_fifo_ctrl3_t fifo_ctrl3;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL3, (uint8_t*)&fifo_ctrl3, 1);
+
+    switch(fifo_ctrl3.dec_fifo_gyro) {
+    case LSM6DS3TR_C_FIFO_GY_DISABLE:
+        *val = LSM6DS3TR_C_FIFO_GY_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_FIFO_GY_NO_DEC:
+        *val = LSM6DS3TR_C_FIFO_GY_NO_DEC;
+        break;
+
+    case LSM6DS3TR_C_FIFO_GY_DEC_2:
+        *val = LSM6DS3TR_C_FIFO_GY_DEC_2;
+        break;
+
+    case LSM6DS3TR_C_FIFO_GY_DEC_3:
+        *val = LSM6DS3TR_C_FIFO_GY_DEC_3;
+        break;
+
+    case LSM6DS3TR_C_FIFO_GY_DEC_4:
+        *val = LSM6DS3TR_C_FIFO_GY_DEC_4;
+        break;
+
+    case LSM6DS3TR_C_FIFO_GY_DEC_8:
+        *val = LSM6DS3TR_C_FIFO_GY_DEC_8;
+        break;
+
+    case LSM6DS3TR_C_FIFO_GY_DEC_16:
+        *val = LSM6DS3TR_C_FIFO_GY_DEC_16;
+        break;
+
+    case LSM6DS3TR_C_FIFO_GY_DEC_32:
+        *val = LSM6DS3TR_C_FIFO_GY_DEC_32;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_FIFO_GY_DEC_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief   Selects Batching Data Rate (writing frequency in FIFO)
+  *          for third data set.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of dec_ds3_fifo in reg FIFO_CTRL4
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_dataset_3_batch_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_ds3_fifo_t val) {
+    lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+
+    if(ret == 0) {
+        fifo_ctrl4.dec_ds3_fifo = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief   Selects Batching Data Rate (writing frequency in FIFO)
+  *          for third data set.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of dec_ds3_fifo in reg FIFO_CTRL4
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_dataset_3_batch_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_ds3_fifo_t* val) {
+    lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+
+    switch(fifo_ctrl4.dec_ds3_fifo) {
+    case LSM6DS3TR_C_FIFO_DS3_DISABLE:
+        *val = LSM6DS3TR_C_FIFO_DS3_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS3_NO_DEC:
+        *val = LSM6DS3TR_C_FIFO_DS3_NO_DEC;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS3_DEC_2:
+        *val = LSM6DS3TR_C_FIFO_DS3_DEC_2;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS3_DEC_3:
+        *val = LSM6DS3TR_C_FIFO_DS3_DEC_3;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS3_DEC_4:
+        *val = LSM6DS3TR_C_FIFO_DS3_DEC_4;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS3_DEC_8:
+        *val = LSM6DS3TR_C_FIFO_DS3_DEC_8;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS3_DEC_16:
+        *val = LSM6DS3TR_C_FIFO_DS3_DEC_16;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS3_DEC_32:
+        *val = LSM6DS3TR_C_FIFO_DS3_DEC_32;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_FIFO_DS3_DEC_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief   Selects Batching Data Rate (writing frequency in FIFO)
+  *          for fourth data set.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of dec_ds4_fifo in reg FIFO_CTRL4
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_dataset_4_batch_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_ds4_fifo_t val) {
+    lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+
+    if(ret == 0) {
+        fifo_ctrl4.dec_ds4_fifo = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief   Selects Batching Data Rate (writing frequency in FIFO) for
+  *          fourth data set.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of dec_ds4_fifo in reg FIFO_CTRL4
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_dataset_4_batch_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_ds4_fifo_t* val) {
+    lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+
+    switch(fifo_ctrl4.dec_ds4_fifo) {
+    case LSM6DS3TR_C_FIFO_DS4_DISABLE:
+        *val = LSM6DS3TR_C_FIFO_DS4_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS4_NO_DEC:
+        *val = LSM6DS3TR_C_FIFO_DS4_NO_DEC;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS4_DEC_2:
+        *val = LSM6DS3TR_C_FIFO_DS4_DEC_2;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS4_DEC_3:
+        *val = LSM6DS3TR_C_FIFO_DS4_DEC_3;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS4_DEC_4:
+        *val = LSM6DS3TR_C_FIFO_DS4_DEC_4;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS4_DEC_8:
+        *val = LSM6DS3TR_C_FIFO_DS4_DEC_8;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS4_DEC_16:
+        *val = LSM6DS3TR_C_FIFO_DS4_DEC_16;
+        break;
+
+    case LSM6DS3TR_C_FIFO_DS4_DEC_32:
+        *val = LSM6DS3TR_C_FIFO_DS4_DEC_32;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_FIFO_DS4_DEC_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief   8-bit data storage in FIFO.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of only_high_data in reg FIFO_CTRL4
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_xl_gy_8bit_format_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+
+    if(ret == 0) {
+        fifo_ctrl4.only_high_data = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  8-bit data storage in FIFO.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of only_high_data in reg FIFO_CTRL4
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_xl_gy_8bit_format_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+    *val = fifo_ctrl4.only_high_data;
+
+    return ret;
+}
+
+/**
+  * @brief  Sensing chain FIFO stop values memorization at threshold
+  *         level.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of stop_on_fth in reg FIFO_CTRL4
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_stop_on_wtm_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+
+    if(ret == 0) {
+        fifo_ctrl4.stop_on_fth = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Sensing chain FIFO stop values memorization at threshold
+  *         level.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of stop_on_fth in reg FIFO_CTRL4
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_stop_on_wtm_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL4, (uint8_t*)&fifo_ctrl4, 1);
+    *val = fifo_ctrl4.stop_on_fth;
+
+    return ret;
+}
+
+/**
+  * @brief  FIFO mode selection.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of fifo_mode in reg FIFO_CTRL5
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_fifo_mode_t val) {
+    lsm6ds3tr_c_fifo_ctrl5_t fifo_ctrl5;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5, (uint8_t*)&fifo_ctrl5, 1);
+
+    if(ret == 0) {
+        fifo_ctrl5.fifo_mode = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5, (uint8_t*)&fifo_ctrl5, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  FIFO mode selection.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of fifo_mode in reg FIFO_CTRL5
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_fifo_mode_t* val) {
+    lsm6ds3tr_c_fifo_ctrl5_t fifo_ctrl5;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5, (uint8_t*)&fifo_ctrl5, 1);
+
+    switch(fifo_ctrl5.fifo_mode) {
+    case LSM6DS3TR_C_BYPASS_MODE:
+        *val = LSM6DS3TR_C_BYPASS_MODE;
+        break;
+
+    case LSM6DS3TR_C_FIFO_MODE:
+        *val = LSM6DS3TR_C_FIFO_MODE;
+        break;
+
+    case LSM6DS3TR_C_STREAM_TO_FIFO_MODE:
+        *val = LSM6DS3TR_C_STREAM_TO_FIFO_MODE;
+        break;
+
+    case LSM6DS3TR_C_BYPASS_TO_STREAM_MODE:
+        *val = LSM6DS3TR_C_BYPASS_TO_STREAM_MODE;
+        break;
+
+    case LSM6DS3TR_C_STREAM_MODE:
+        *val = LSM6DS3TR_C_STREAM_MODE;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_FIFO_MODE_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  FIFO ODR selection, setting FIFO_MODE also.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of odr_fifo in reg FIFO_CTRL5
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_data_rate_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_fifo_t val) {
+    lsm6ds3tr_c_fifo_ctrl5_t fifo_ctrl5;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5, (uint8_t*)&fifo_ctrl5, 1);
+
+    if(ret == 0) {
+        fifo_ctrl5.odr_fifo = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5, (uint8_t*)&fifo_ctrl5, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  FIFO ODR selection, setting FIFO_MODE also.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of odr_fifo in reg FIFO_CTRL5
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_fifo_data_rate_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_fifo_t* val) {
+    lsm6ds3tr_c_fifo_ctrl5_t fifo_ctrl5;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_FIFO_CTRL5, (uint8_t*)&fifo_ctrl5, 1);
+
+    switch(fifo_ctrl5.odr_fifo) {
+    case LSM6DS3TR_C_FIFO_DISABLE:
+        *val = LSM6DS3TR_C_FIFO_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_FIFO_12Hz5:
+        *val = LSM6DS3TR_C_FIFO_12Hz5;
+        break;
+
+    case LSM6DS3TR_C_FIFO_26Hz:
+        *val = LSM6DS3TR_C_FIFO_26Hz;
+        break;
+
+    case LSM6DS3TR_C_FIFO_52Hz:
+        *val = LSM6DS3TR_C_FIFO_52Hz;
+        break;
+
+    case LSM6DS3TR_C_FIFO_104Hz:
+        *val = LSM6DS3TR_C_FIFO_104Hz;
+        break;
+
+    case LSM6DS3TR_C_FIFO_208Hz:
+        *val = LSM6DS3TR_C_FIFO_208Hz;
+        break;
+
+    case LSM6DS3TR_C_FIFO_416Hz:
+        *val = LSM6DS3TR_C_FIFO_416Hz;
+        break;
+
+    case LSM6DS3TR_C_FIFO_833Hz:
+        *val = LSM6DS3TR_C_FIFO_833Hz;
+        break;
+
+    case LSM6DS3TR_C_FIFO_1k66Hz:
+        *val = LSM6DS3TR_C_FIFO_1k66Hz;
+        break;
+
+    case LSM6DS3TR_C_FIFO_3k33Hz:
+        *val = LSM6DS3TR_C_FIFO_3k33Hz;
+        break;
+
+    case LSM6DS3TR_C_FIFO_6k66Hz:
+        *val = LSM6DS3TR_C_FIFO_6k66Hz;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_FIFO_RATE_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_DEN_functionality
+  * @brief       This section groups all the functions concerning DEN
+  *              functionality.
+  * @{
+  *
+  */
+
+/**
+  * @brief  DEN active level configuration.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of den_lh in reg CTRL5_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_polarity_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_lh_t val) {
+    lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+
+    if(ret == 0) {
+        ctrl5_c.den_lh = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  DEN active level configuration.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of den_lh in reg CTRL5_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_polarity_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_lh_t* val) {
+    lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL5_C, (uint8_t*)&ctrl5_c, 1);
+
+    switch(ctrl5_c.den_lh) {
+    case LSM6DS3TR_C_DEN_ACT_LOW:
+        *val = LSM6DS3TR_C_DEN_ACT_LOW;
+        break;
+
+    case LSM6DS3TR_C_DEN_ACT_HIGH:
+        *val = LSM6DS3TR_C_DEN_ACT_HIGH;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_DEN_POL_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  DEN functionality marking mode[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of den_mode in reg CTRL6_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_mode_t val) {
+    lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+
+    if(ret == 0) {
+        ctrl6_c.den_mode = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  DEN functionality marking mode[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of den_mode in reg CTRL6_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_mode_t* val) {
+    lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL6_C, (uint8_t*)&ctrl6_c, 1);
+
+    switch(ctrl6_c.den_mode) {
+    case LSM6DS3TR_C_DEN_DISABLE:
+        *val = LSM6DS3TR_C_DEN_DISABLE;
+        break;
+
+    case LSM6DS3TR_C_LEVEL_LETCHED:
+        *val = LSM6DS3TR_C_LEVEL_LETCHED;
+        break;
+
+    case LSM6DS3TR_C_LEVEL_TRIGGER:
+        *val = LSM6DS3TR_C_LEVEL_TRIGGER;
+        break;
+
+    case LSM6DS3TR_C_EDGE_TRIGGER:
+        *val = LSM6DS3TR_C_EDGE_TRIGGER;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_DEN_MODE_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Extend DEN functionality to accelerometer sensor.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of den_xl_g in reg CTRL9_XL
+  *                             and den_xl_en in CTRL4_C.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_enable_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_xl_en_t val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+
+    if(ret == 0) {
+        ctrl9_xl.den_xl_g = (uint8_t)val & 0x01U;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+
+            if(ret == 0) {
+                ctrl4_c.den_xl_en = (uint8_t)val & 0x02U;
+                ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Extend DEN functionality to accelerometer sensor. [get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of den_xl_g in reg CTRL9_XL
+  *                             and den_xl_en in CTRL4_C.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_enable_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_xl_en_t* val) {
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL4_C, (uint8_t*)&ctrl4_c, 1);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+
+        switch((ctrl4_c.den_xl_en << 1) + ctrl9_xl.den_xl_g) {
+        case LSM6DS3TR_C_STAMP_IN_GY_DATA:
+            *val = LSM6DS3TR_C_STAMP_IN_GY_DATA;
+            break;
+
+        case LSM6DS3TR_C_STAMP_IN_XL_DATA:
+            *val = LSM6DS3TR_C_STAMP_IN_XL_DATA;
+            break;
+
+        case LSM6DS3TR_C_STAMP_IN_GY_XL_DATA:
+            *val = LSM6DS3TR_C_STAMP_IN_GY_XL_DATA;
+            break;
+
+        default:
+            *val = LSM6DS3TR_C_DEN_STAMP_ND;
+            break;
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  DEN value stored in LSB of Z-axis.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of den_z in reg CTRL9_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_mark_axis_z_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+
+    if(ret == 0) {
+        ctrl9_xl.den_z = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  DEN value stored in LSB of Z-axis.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of den_z in reg CTRL9_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_mark_axis_z_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+    *val = ctrl9_xl.den_z;
+
+    return ret;
+}
+
+/**
+  * @brief  DEN value stored in LSB of Y-axis.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of den_y in reg CTRL9_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_mark_axis_y_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+
+    if(ret == 0) {
+        ctrl9_xl.den_y = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  DEN value stored in LSB of Y-axis.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of den_y in reg CTRL9_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_mark_axis_y_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+    *val = ctrl9_xl.den_y;
+
+    return ret;
+}
+
+/**
+  * @brief  DEN value stored in LSB of X-axis.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of den_x in reg CTRL9_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_mark_axis_x_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+
+    if(ret == 0) {
+        ctrl9_xl.den_x = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  DEN value stored in LSB of X-axis.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of den_x in reg CTRL9_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_den_mark_axis_x_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+    *val = ctrl9_xl.den_x;
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_Pedometer
+  * @brief       This section groups all the functions that manage pedometer.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Reset pedometer step counter.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of pedo_rst_step in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_step_reset_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+
+    if(ret == 0) {
+        ctrl10_c.pedo_rst_step = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Reset pedometer step counter.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of pedo_rst_step in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_step_reset_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    *val = ctrl10_c.pedo_rst_step;
+
+    return ret;
+}
+
+/**
+  * @brief  Enable pedometer algorithm.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of pedo_en in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_sens_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+
+    if(ret == 0) {
+        ctrl10_c.pedo_en = val;
+
+        if(val != 0x00U) {
+            ctrl10_c.func_en = val;
+        }
+
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  pedo_sens:   Enable pedometer algorithm.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of pedo_en in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_sens_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    *val = ctrl10_c.pedo_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Minimum threshold to detect a peak. Default is 10h.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of ths_min in reg
+  *                      CONFIG_PEDO_THS_MIN
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_threshold_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_config_pedo_ths_min_t config_pedo_ths_min;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(
+            ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN, (uint8_t*)&config_pedo_ths_min, 1);
+
+        if(ret == 0) {
+            config_pedo_ths_min.ths_min = val;
+            ret = lsm6ds3tr_c_write_reg(
+                ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN, (uint8_t*)&config_pedo_ths_min, 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Minimum threshold to detect a peak. Default is 10h.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of ths_min in reg  CONFIG_PEDO_THS_MIN
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_threshold_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_config_pedo_ths_min_t config_pedo_ths_min;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(
+            ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN, (uint8_t*)&config_pedo_ths_min, 1);
+
+        if(ret == 0) {
+            *val = config_pedo_ths_min.ths_min;
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  pedo_full_scale:   Pedometer data range.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of pedo_fs in
+  *                            reg CONFIG_PEDO_THS_MIN
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_full_scale_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_pedo_fs_t val) {
+    lsm6ds3tr_c_config_pedo_ths_min_t config_pedo_ths_min;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(
+            ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN, (uint8_t*)&config_pedo_ths_min, 1);
+
+        if(ret == 0) {
+            config_pedo_ths_min.pedo_fs = (uint8_t)val;
+            ret = lsm6ds3tr_c_write_reg(
+                ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN, (uint8_t*)&config_pedo_ths_min, 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Pedometer data range.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of pedo_fs in
+  *                            reg CONFIG_PEDO_THS_MIN
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_full_scale_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_pedo_fs_t* val) {
+    lsm6ds3tr_c_config_pedo_ths_min_t config_pedo_ths_min;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(
+            ctx, LSM6DS3TR_C_CONFIG_PEDO_THS_MIN, (uint8_t*)&config_pedo_ths_min, 1);
+
+        if(ret == 0) {
+            switch(config_pedo_ths_min.pedo_fs) {
+            case LSM6DS3TR_C_PEDO_AT_2g:
+                *val = LSM6DS3TR_C_PEDO_AT_2g;
+                break;
+
+            case LSM6DS3TR_C_PEDO_AT_4g:
+                *val = LSM6DS3TR_C_PEDO_AT_4g;
+                break;
+
+            default:
+                *val = LSM6DS3TR_C_PEDO_FS_ND;
+                break;
+            }
+
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Pedometer debounce configuration register (r/w).[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of deb_step in reg PEDO_DEB_REG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_debounce_steps_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_pedo_deb_reg_t pedo_deb_reg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG, (uint8_t*)&pedo_deb_reg, 1);
+
+        if(ret == 0) {
+            pedo_deb_reg.deb_step = val;
+            ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG, (uint8_t*)&pedo_deb_reg, 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Pedometer debounce configuration register (r/w).[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of deb_step in reg PEDO_DEB_REG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_debounce_steps_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_pedo_deb_reg_t pedo_deb_reg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG, (uint8_t*)&pedo_deb_reg, 1);
+
+        if(ret == 0) {
+            *val = pedo_deb_reg.deb_step;
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Debounce time. If the time between two consecutive steps is
+  *         greater than  DEB_TIME*80ms, the debouncer is reactivated.
+  *         Default value: 01101[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of deb_time in reg PEDO_DEB_REG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_timeout_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_pedo_deb_reg_t pedo_deb_reg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG, (uint8_t*)&pedo_deb_reg, 1);
+
+        if(ret == 0) {
+            pedo_deb_reg.deb_time = val;
+            ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG, (uint8_t*)&pedo_deb_reg, 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Debounce time. If the time between two consecutive steps is
+  *         greater than  DEB_TIME*80ms, the debouncer is reactivated.
+  *         Default value: 01101[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of deb_time in reg PEDO_DEB_REG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_timeout_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_pedo_deb_reg_t pedo_deb_reg;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_PEDO_DEB_REG, (uint8_t*)&pedo_deb_reg, 1);
+
+        if(ret == 0) {
+            *val = pedo_deb_reg.deb_time;
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Time period register for step detection on delta time (r/w).[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that contains data to write
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_steps_period_set(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_STEP_COUNT_DELTA, buff, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Time period register for step detection on delta time (r/w).[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_pedo_steps_period_get(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_STEP_COUNT_DELTA, buff, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_significant_motion
+  * @brief       This section groups all the functions that manage the
+  *              significant motion detection.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Enable significant motion detection function.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of sign_motion_en in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_motion_sens_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+
+    if(ret == 0) {
+        ctrl10_c.sign_motion_en = val;
+
+        if(val != 0x00U) {
+            ctrl10_c.func_en = val;
+            ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable significant motion detection function.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of sign_motion_en in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_motion_sens_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    *val = ctrl10_c.sign_motion_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Significant motion threshold.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that store significant motion threshold.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_motion_threshold_set(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SM_THS, buff, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Significant motion threshold.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that store significant motion threshold.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_motion_threshold_get(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SM_THS, buff, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_tilt_detection
+  * @brief       This section groups all the functions that manage the tilt
+  *              event detection.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Enable tilt calculation.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tilt_en in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tilt_sens_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+
+    if(ret == 0) {
+        ctrl10_c.tilt_en = val;
+
+        if(val != 0x00U) {
+            ctrl10_c.func_en = val;
+        }
+
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable tilt calculation.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tilt_en in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tilt_sens_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    *val = ctrl10_c.tilt_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Enable tilt calculation.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tilt_en in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_wrist_tilt_sens_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+
+    if(ret == 0) {
+        ctrl10_c.wrist_tilt_en = val;
+
+        if(val != 0x00U) {
+            ctrl10_c.func_en = val;
+        }
+
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable tilt calculation.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tilt_en in reg CTRL10_C
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_wrist_tilt_sens_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    *val = ctrl10_c.wrist_tilt_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Absolute Wrist Tilt latency register (r/w).
+  *         Absolute wrist tilt latency parameters.
+  *         1 LSB = 40 ms. Default value: 0Fh (600 ms).[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that contains data to write
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tilt_latency_set(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_LAT, buff, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Absolute Wrist Tilt latency register (r/w).
+  *         Absolute wrist tilt latency parameters.
+  *         1 LSB = 40 ms. Default value: 0Fh (600 ms).[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tilt_latency_get(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_LAT, buff, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Absolute Wrist Tilt threshold register(r/w).
+  *         Absolute wrist tilt threshold parameters.
+  *         1 LSB = 15.625 mg.Default value: 20h (500 mg).[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that contains data to write
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tilt_threshold_set(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_THS, buff, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Absolute Wrist Tilt threshold register(r/w).
+  *         Absolute wrist tilt threshold parameters.
+  *         1 LSB = 15.625 mg.Default value: 20h (500 mg).[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tilt_threshold_get(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_THS, buff, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Absolute Wrist Tilt mask register (r/w).[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Registers A_WRIST_TILT_MASK
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tilt_src_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_a_wrist_tilt_mask_t* val) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_MASK, (uint8_t*)val, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Absolute Wrist Tilt mask register (r/w).[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Registers A_WRIST_TILT_MASK
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_tilt_src_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_a_wrist_tilt_mask_t* val) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_B);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_A_WRIST_TILT_MASK, (uint8_t*)val, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_ magnetometer_sensor
+  * @brief       This section groups all the functions that manage additional
+  *              magnetometer sensor.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Enable soft-iron correction algorithm for magnetometer.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of soft_en in reg CTRL9_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mag_soft_iron_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+
+    if(ret == 0) {
+        ctrl9_xl.soft_en = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable soft-iron correction algorithm for magnetometer.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of soft_en in reg CTRL9_XL
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mag_soft_iron_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL9_XL, (uint8_t*)&ctrl9_xl, 1);
+    *val = ctrl9_xl.soft_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Enable hard-iron correction algorithm for magnetometer.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of iron_en in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mag_hard_iron_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+    if(ret == 0) {
+        master_config.iron_en = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+
+            if(ret == 0) {
+                if(val != 0x00U) {
+                    ctrl10_c.func_en = val;
+                }
+
+                ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Enable hard-iron correction algorithm for magnetometer.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of iron_en in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mag_hard_iron_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    *val = master_config.iron_en;
+
+    return ret;
+}
+
+/**
+  * @brief  Soft iron 3x3 matrix. Value are expressed in sign-module format.
+  *         (Es. SVVVVVVVb where S is the sign 0/+1/- and V is the value).[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that contains data to write
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mag_soft_iron_mat_set(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MAG_SI_XX, buff, 9);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Soft iron 3x3 matrix. Value are expressed in sign-module format.
+  *         (Es. SVVVVVVVb where S is the sign 0/+1/- and V is the value).[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mag_soft_iron_mat_get(stmdev_ctx_t* ctx, uint8_t* buff) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MAG_SI_XX, buff, 9);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Offset for hard-iron compensation register (r/w). The value is
+  *         expressed as a 16-bit word in two’s complement.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that contains data to write
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mag_offset_set(stmdev_ctx_t* ctx, int16_t* val) {
+    uint8_t buff[6];
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        buff[1] = (uint8_t)((uint16_t)val[0] / 256U);
+        buff[0] = (uint8_t)((uint16_t)val[0] - (buff[1] * 256U));
+        buff[3] = (uint8_t)((uint16_t)val[1] / 256U);
+        buff[2] = (uint8_t)((uint16_t)val[1] - (buff[3] * 256U));
+        buff[5] = (uint8_t)((uint16_t)val[2] / 256U);
+        buff[4] = (uint8_t)((uint16_t)val[2] - (buff[5] * 256U));
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MAG_OFFX_L, buff, 6);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Offset for hard-iron compensation register(r/w).
+  *         The value is expressed as a 16-bit word in two’s complement.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  buff   Buffer that stores data read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_mag_offset_get(stmdev_ctx_t* ctx, int16_t* val) {
+    uint8_t buff[6];
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MAG_OFFX_L, buff, 6);
+
+        if(ret == 0) {
+            val[0] = (int16_t)buff[1];
+            val[0] = (val[0] * 256) + (int16_t)buff[0];
+            val[1] = (int16_t)buff[3];
+            val[1] = (val[1] * 256) + (int16_t)buff[2];
+            val[2] = (int16_t)buff[5];
+            val[2] = (val[2] * 256) + (int16_t)buff[4];
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @defgroup    LSM6DS3TR_C_Sensor_hub
+  * @brief       This section groups all the functions that manage the sensor
+  *              hub functionality.
+  * @{
+  *
+  */
+
+/**
+  * @brief  Enable function.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values func_en
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_func_en_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+
+    if(ret == 0) {
+        ctrl10_c.func_en = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_CTRL10_C, (uint8_t*)&ctrl10_c, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Sensor synchronization time frame with the step of 500 ms and
+  *         full range of 5s. Unsigned 8-bit.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tph in reg SENSOR_SYNC_TIME_FRAME
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_sync_sens_frame_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_sensor_sync_time_frame_t sensor_sync_time_frame;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(
+        ctx, LSM6DS3TR_C_SENSOR_SYNC_TIME_FRAME, (uint8_t*)&sensor_sync_time_frame, 1);
+
+    if(ret == 0) {
+        sensor_sync_time_frame.tph = val;
+        ret = lsm6ds3tr_c_write_reg(
+            ctx, LSM6DS3TR_C_SENSOR_SYNC_TIME_FRAME, (uint8_t*)&sensor_sync_time_frame, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Sensor synchronization time frame with the step of 500 ms and
+  *         full range of 5s. Unsigned 8-bit.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of tph in reg  SENSOR_SYNC_TIME_FRAME
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_sync_sens_frame_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_sensor_sync_time_frame_t sensor_sync_time_frame;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(
+        ctx, LSM6DS3TR_C_SENSOR_SYNC_TIME_FRAME, (uint8_t*)&sensor_sync_time_frame, 1);
+    *val = sensor_sync_time_frame.tph;
+
+    return ret;
+}
+
+/**
+  * @brief  Resolution ratio of error code for sensor synchronization.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of rr in reg  SENSOR_SYNC_RES_RATIO
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_sync_sens_ratio_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_rr_t val) {
+    lsm6ds3tr_c_sensor_sync_res_ratio_t sensor_sync_res_ratio;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(
+        ctx, LSM6DS3TR_C_SENSOR_SYNC_RES_RATIO, (uint8_t*)&sensor_sync_res_ratio, 1);
+
+    if(ret == 0) {
+        sensor_sync_res_ratio.rr = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(
+            ctx, LSM6DS3TR_C_SENSOR_SYNC_RES_RATIO, (uint8_t*)&sensor_sync_res_ratio, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Resolution ratio of error code for sensor synchronization.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of rr in reg  SENSOR_SYNC_RES_RATIO
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_sync_sens_ratio_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_rr_t* val) {
+    lsm6ds3tr_c_sensor_sync_res_ratio_t sensor_sync_res_ratio;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(
+        ctx, LSM6DS3TR_C_SENSOR_SYNC_RES_RATIO, (uint8_t*)&sensor_sync_res_ratio, 1);
+
+    switch(sensor_sync_res_ratio.rr) {
+    case LSM6DS3TR_C_RES_RATIO_2_11:
+        *val = LSM6DS3TR_C_RES_RATIO_2_11;
+        break;
+
+    case LSM6DS3TR_C_RES_RATIO_2_12:
+        *val = LSM6DS3TR_C_RES_RATIO_2_12;
+        break;
+
+    case LSM6DS3TR_C_RES_RATIO_2_13:
+        *val = LSM6DS3TR_C_RES_RATIO_2_13;
+        break;
+
+    case LSM6DS3TR_C_RES_RATIO_2_14:
+        *val = LSM6DS3TR_C_RES_RATIO_2_14;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_RES_RATIO_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Sensor hub I2C master enable.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of master_on in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_master_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+    if(ret == 0) {
+        master_config.master_on = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Sensor hub I2C master enable.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of master_on in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_master_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    *val = master_config.master_on;
+
+    return ret;
+}
+
+/**
+  * @brief  I2C interface pass-through.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of pass_through_mode in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_pass_through_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+    if(ret == 0) {
+        master_config.pass_through_mode = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  I2C interface pass-through.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of pass_through_mode in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_pass_through_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    *val = master_config.pass_through_mode;
+
+    return ret;
+}
+
+/**
+  * @brief  Master I2C pull-up enable/disable.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of pull_up_en in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_pin_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_pull_up_en_t val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+    if(ret == 0) {
+        master_config.pull_up_en = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Master I2C pull-up enable/disable.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of pull_up_en in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_pin_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_pull_up_en_t* val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+    switch(master_config.pull_up_en) {
+    case LSM6DS3TR_C_EXT_PULL_UP:
+        *val = LSM6DS3TR_C_EXT_PULL_UP;
+        break;
+
+    case LSM6DS3TR_C_INTERNAL_PULL_UP:
+        *val = LSM6DS3TR_C_INTERNAL_PULL_UP;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_SH_PIN_MODE;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Sensor hub trigger signal selection.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of start_config in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_syncro_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_start_config_t val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+    if(ret == 0) {
+        master_config.start_config = (uint8_t)val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Sensor hub trigger signal selection.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of start_config in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_syncro_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_start_config_t* val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+    switch(master_config.start_config) {
+    case LSM6DS3TR_C_XL_GY_DRDY:
+        *val = LSM6DS3TR_C_XL_GY_DRDY;
+        break;
+
+    case LSM6DS3TR_C_EXT_ON_INT2_PIN:
+        *val = LSM6DS3TR_C_EXT_ON_INT2_PIN;
+        break;
+
+    default:
+        *val = LSM6DS3TR_C_SH_SYNCRO_ND;
+        break;
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Manage the Master DRDY signal on INT1 pad.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of drdy_on_int1 in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_drdy_on_int1_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+
+    if(ret == 0) {
+        master_config.drdy_on_int1 = val;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Manage the Master DRDY signal on INT1 pad.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of drdy_on_int1 in reg MASTER_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_drdy_on_int1_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_master_config_t master_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CONFIG, (uint8_t*)&master_config, 1);
+    *val = master_config.drdy_on_int1;
+
+    return ret;
+}
+
+/**
+  * @brief  Sensor hub output registers.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Structure of registers from SENSORHUB1_REG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_read_data_raw_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_emb_sh_read_t* val) {
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SENSORHUB1_REG, (uint8_t*)&(val->sh_byte_1), 12);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(
+            ctx, LSM6DS3TR_C_SENSORHUB13_REG, (uint8_t*)&(val->sh_byte_13), 6);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Master command code used for stamping for sensor sync.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of master_cmd_code in
+  *                reg MASTER_CMD_CODE
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_cmd_sens_sync_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_master_cmd_code_t master_cmd_code;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CMD_CODE, (uint8_t*)&master_cmd_code, 1);
+
+    if(ret == 0) {
+        master_cmd_code.master_cmd_code = val;
+        ret =
+            lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_MASTER_CMD_CODE, (uint8_t*)&master_cmd_code, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Master command code used for stamping for sensor sync.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of master_cmd_code in
+  *                reg MASTER_CMD_CODE
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_cmd_sens_sync_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_master_cmd_code_t master_cmd_code;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_MASTER_CMD_CODE, (uint8_t*)&master_cmd_code, 1);
+    *val = master_cmd_code.master_cmd_code;
+
+    return ret;
+}
+
+/**
+  * @brief  Error code used for sensor synchronization.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of error_code in
+  *                reg SENS_SYNC_SPI_ERROR_CODE.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_spi_sync_error_set(stmdev_ctx_t* ctx, uint8_t val) {
+    lsm6ds3tr_c_sens_sync_spi_error_code_t sens_sync_spi_error_code;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(
+        ctx, LSM6DS3TR_C_SENS_SYNC_SPI_ERROR_CODE, (uint8_t*)&sens_sync_spi_error_code, 1);
+
+    if(ret == 0) {
+        sens_sync_spi_error_code.error_code = val;
+        ret = lsm6ds3tr_c_write_reg(
+            ctx, LSM6DS3TR_C_SENS_SYNC_SPI_ERROR_CODE, (uint8_t*)&sens_sync_spi_error_code, 1);
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Error code used for sensor synchronization.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of error_code in
+  *                reg SENS_SYNC_SPI_ERROR_CODE.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_spi_sync_error_get(stmdev_ctx_t* ctx, uint8_t* val) {
+    lsm6ds3tr_c_sens_sync_spi_error_code_t sens_sync_spi_error_code;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_read_reg(
+        ctx, LSM6DS3TR_C_SENS_SYNC_SPI_ERROR_CODE, (uint8_t*)&sens_sync_spi_error_code, 1);
+    *val = sens_sync_spi_error_code.error_code;
+
+    return ret;
+}
+
+/**
+  * @brief   Number of external sensors to be read by the sensor hub.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of aux_sens_on in reg SLAVE0_CONFIG.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_num_of_dev_connected_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_aux_sens_on_t val) {
+    lsm6ds3tr_c_slave0_config_t slave0_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG, (uint8_t*)&slave0_config, 1);
+
+        if(ret == 0) {
+            slave0_config.aux_sens_on = (uint8_t)val;
+            ret =
+                lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG, (uint8_t*)&slave0_config, 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief   Number of external sensors to be read by the sensor hub.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of aux_sens_on in reg SLAVE0_CONFIG.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t
+    lsm6ds3tr_c_sh_num_of_dev_connected_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_aux_sens_on_t* val) {
+    lsm6ds3tr_c_slave0_config_t slave0_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG, (uint8_t*)&slave0_config, 1);
+
+        if(ret == 0) {
+            switch(slave0_config.aux_sens_on) {
+            case LSM6DS3TR_C_SLV_0:
+                *val = LSM6DS3TR_C_SLV_0;
+                break;
+
+            case LSM6DS3TR_C_SLV_0_1:
+                *val = LSM6DS3TR_C_SLV_0_1;
+                break;
+
+            case LSM6DS3TR_C_SLV_0_1_2:
+                *val = LSM6DS3TR_C_SLV_0_1_2;
+                break;
+
+            case LSM6DS3TR_C_SLV_0_1_2_3:
+                *val = LSM6DS3TR_C_SLV_0_1_2_3;
+                break;
+
+            default:
+                *val = LSM6DS3TR_C_SLV_EN_ND;
+                break;
+            }
+
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Configure slave 0 for perform a write.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Structure that contain:
+  *                  - uint8_t slv_add;    8 bit i2c device address
+  *                  - uint8_t slv_subadd; 8 bit register device address
+  *                  - uint8_t slv_data;   8 bit data to write
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_cfg_write(stmdev_ctx_t* ctx, lsm6ds3tr_c_sh_cfg_write_t* val) {
+    lsm6ds3tr_c_slv0_add_t slv0_add;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        slv0_add.slave0_add = val->slv0_add;
+        slv0_add.rw_0 = 0;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV0_ADD, (uint8_t*)&slv0_add, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV0_SUBADD, &(val->slv0_subadd), 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_write_reg(
+                    ctx, LSM6DS3TR_C_DATAWRITE_SRC_MODE_SUB_SLV0, &(val->slv0_data), 1);
+
+                if(ret == 0) {
+                    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+                }
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Configure slave 0 for perform a read.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Structure that contain:
+  *                  - uint8_t slv_add;    8 bit i2c device address
+  *                  - uint8_t slv_subadd; 8 bit register device address
+  *                  - uint8_t slv_len;    num of bit to read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slv0_cfg_read(stmdev_ctx_t* ctx, lsm6ds3tr_c_sh_cfg_read_t* val) {
+    lsm6ds3tr_c_slave0_config_t slave0_config;
+    lsm6ds3tr_c_slv0_add_t slv0_add;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        slv0_add.slave0_add = val->slv_add;
+        slv0_add.rw_0 = 1;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV0_ADD, (uint8_t*)&slv0_add, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV0_SUBADD, &(val->slv_subadd), 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_read_reg(
+                    ctx, LSM6DS3TR_C_SLAVE0_CONFIG, (uint8_t*)&slave0_config, 1);
+                slave0_config.slave0_numop = val->slv_len;
+
+                if(ret == 0) {
+                    ret = lsm6ds3tr_c_write_reg(
+                        ctx, LSM6DS3TR_C_SLAVE0_CONFIG, (uint8_t*)&slave0_config, 1);
+
+                    if(ret == 0) {
+                        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+                    }
+                }
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Configure slave 1 for perform a read.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Structure that contain:
+  *                  - uint8_t slv_add;    8 bit i2c device address
+  *                  - uint8_t slv_subadd; 8 bit register device address
+  *                  - uint8_t slv_len;    num of bit to read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slv1_cfg_read(stmdev_ctx_t* ctx, lsm6ds3tr_c_sh_cfg_read_t* val) {
+    lsm6ds3tr_c_slave1_config_t slave1_config;
+    lsm6ds3tr_c_slv1_add_t slv1_add;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        slv1_add.slave1_add = val->slv_add;
+        slv1_add.r_1 = 1;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV1_ADD, (uint8_t*)&slv1_add, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV1_SUBADD, &(val->slv_subadd), 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_read_reg(
+                    ctx, LSM6DS3TR_C_SLAVE1_CONFIG, (uint8_t*)&slave1_config, 1);
+                slave1_config.slave1_numop = val->slv_len;
+
+                if(ret == 0) {
+                    ret = lsm6ds3tr_c_write_reg(
+                        ctx, LSM6DS3TR_C_SLAVE1_CONFIG, (uint8_t*)&slave1_config, 1);
+
+                    if(ret == 0) {
+                        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+                    }
+                }
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Configure slave 2 for perform a read.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Structure that contain:
+  *                  - uint8_t slv_add;    8 bit i2c device address
+  *                  - uint8_t slv_subadd; 8 bit register device address
+  *                  - uint8_t slv_len;    num of bit to read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slv2_cfg_read(stmdev_ctx_t* ctx, lsm6ds3tr_c_sh_cfg_read_t* val) {
+    lsm6ds3tr_c_slv2_add_t slv2_add;
+    lsm6ds3tr_c_slave2_config_t slave2_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        slv2_add.slave2_add = val->slv_add;
+        slv2_add.r_2 = 1;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV2_ADD, (uint8_t*)&slv2_add, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV2_SUBADD, &(val->slv_subadd), 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_read_reg(
+                    ctx, LSM6DS3TR_C_SLAVE2_CONFIG, (uint8_t*)&slave2_config, 1);
+
+                if(ret == 0) {
+                    slave2_config.slave2_numop = val->slv_len;
+                    ret = lsm6ds3tr_c_write_reg(
+                        ctx, LSM6DS3TR_C_SLAVE2_CONFIG, (uint8_t*)&slave2_config, 1);
+
+                    if(ret == 0) {
+                        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+                    }
+                }
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Configure slave 3 for perform a read.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Structure that contain:
+  *                  - uint8_t slv_add;    8 bit i2c device address
+  *                  - uint8_t slv_subadd; 8 bit register device address
+  *                  - uint8_t slv_len;    num of bit to read
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slv3_cfg_read(stmdev_ctx_t* ctx, lsm6ds3tr_c_sh_cfg_read_t* val) {
+    lsm6ds3tr_c_slave3_config_t slave3_config;
+    lsm6ds3tr_c_slv3_add_t slv3_add;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        slv3_add.slave3_add = val->slv_add;
+        slv3_add.r_3 = 1;
+        ret = lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLV3_ADD, (uint8_t*)&slv3_add, 1);
+
+        if(ret == 0) {
+            ret = lsm6ds3tr_c_write_reg(
+                ctx, LSM6DS3TR_C_SLV3_SUBADD, (uint8_t*)&(val->slv_subadd), 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_read_reg(
+                    ctx, LSM6DS3TR_C_SLAVE3_CONFIG, (uint8_t*)&slave3_config, 1);
+
+                if(ret == 0) {
+                    slave3_config.slave3_numop = val->slv_len;
+                    ret = lsm6ds3tr_c_write_reg(
+                        ctx, LSM6DS3TR_C_SLAVE3_CONFIG, (uint8_t*)&slave3_config, 1);
+
+                    if(ret == 0) {
+                        ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+                    }
+                }
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Decimation of read operation on Slave 0 starting from the
+  *         sensor hub trigger.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of slave0_rate in reg SLAVE0_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slave_0_dec_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave0_rate_t val) {
+    lsm6ds3tr_c_slave0_config_t slave0_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG, (uint8_t*)&slave0_config, 1);
+
+        if(ret == 0) {
+            slave0_config.slave0_rate = (uint8_t)val;
+            ret =
+                lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG, (uint8_t*)&slave0_config, 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Decimation of read operation on Slave 0 starting from the
+  *         sensor hub trigger.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of slave0_rate in reg SLAVE0_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slave_0_dec_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave0_rate_t* val) {
+    lsm6ds3tr_c_slave0_config_t slave0_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE0_CONFIG, (uint8_t*)&slave0_config, 1);
+
+        if(ret == 0) {
+            switch(slave0_config.slave0_rate) {
+            case LSM6DS3TR_C_SL0_NO_DEC:
+                *val = LSM6DS3TR_C_SL0_NO_DEC;
+                break;
+
+            case LSM6DS3TR_C_SL0_DEC_2:
+                *val = LSM6DS3TR_C_SL0_DEC_2;
+                break;
+
+            case LSM6DS3TR_C_SL0_DEC_4:
+                *val = LSM6DS3TR_C_SL0_DEC_4;
+                break;
+
+            case LSM6DS3TR_C_SL0_DEC_8:
+                *val = LSM6DS3TR_C_SL0_DEC_8;
+                break;
+
+            default:
+                *val = LSM6DS3TR_C_SL0_DEC_ND;
+                break;
+            }
+
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Slave 0 write operation is performed only at the first sensor
+  *         hub cycle.
+  *         This is effective if the Aux_sens_on[1:0] field in
+  *         SLAVE0_CONFIG(04h) is set to a value other than 00.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of write_once in reg SLAVE1_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_write_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_write_once_t val) {
+    lsm6ds3tr_c_slave1_config_t slave1_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG, (uint8_t*)&slave1_config, 1);
+        slave1_config.write_once = (uint8_t)val;
+
+        if(ret == 0) {
+            ret =
+                lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG, (uint8_t*)&slave1_config, 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Slave 0 write operation is performed only at the first sensor
+  *         hub cycle.
+  *         This is effective if the Aux_sens_on[1:0] field in
+  *         SLAVE0_CONFIG(04h) is set to a value other than 00.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of write_once in reg SLAVE1_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_write_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_write_once_t* val) {
+    lsm6ds3tr_c_slave1_config_t slave1_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG, (uint8_t*)&slave1_config, 1);
+
+        if(ret == 0) {
+            switch(slave1_config.write_once) {
+            case LSM6DS3TR_C_EACH_SH_CYCLE:
+                *val = LSM6DS3TR_C_EACH_SH_CYCLE;
+                break;
+
+            case LSM6DS3TR_C_ONLY_FIRST_CYCLE:
+                *val = LSM6DS3TR_C_ONLY_FIRST_CYCLE;
+                break;
+
+            default:
+                *val = LSM6DS3TR_C_SH_WR_MODE_ND;
+                break;
+            }
+
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Decimation of read operation on Slave 1 starting from the
+  *         sensor hub trigger.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of slave1_rate in reg SLAVE1_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slave_1_dec_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave1_rate_t val) {
+    lsm6ds3tr_c_slave1_config_t slave1_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG, (uint8_t*)&slave1_config, 1);
+
+        if(ret == 0) {
+            slave1_config.slave1_rate = (uint8_t)val;
+            ret =
+                lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG, (uint8_t*)&slave1_config, 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Decimation of read operation on Slave 1 starting from the
+  *         sensor hub trigger.[get]
+  *
+  * @param  ctx    Read / write interface definitions reg SLAVE1_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slave_1_dec_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave1_rate_t* val) {
+    lsm6ds3tr_c_slave1_config_t slave1_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE1_CONFIG, (uint8_t*)&slave1_config, 1);
+
+        if(ret == 0) {
+            switch(slave1_config.slave1_rate) {
+            case LSM6DS3TR_C_SL1_NO_DEC:
+                *val = LSM6DS3TR_C_SL1_NO_DEC;
+                break;
+
+            case LSM6DS3TR_C_SL1_DEC_2:
+                *val = LSM6DS3TR_C_SL1_DEC_2;
+                break;
+
+            case LSM6DS3TR_C_SL1_DEC_4:
+                *val = LSM6DS3TR_C_SL1_DEC_4;
+                break;
+
+            case LSM6DS3TR_C_SL1_DEC_8:
+                *val = LSM6DS3TR_C_SL1_DEC_8;
+                break;
+
+            default:
+                *val = LSM6DS3TR_C_SL1_DEC_ND;
+                break;
+            }
+
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Decimation of read operation on Slave 2 starting from the
+  *         sensor hub trigger.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of slave2_rate in reg SLAVE2_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slave_2_dec_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave2_rate_t val) {
+    lsm6ds3tr_c_slave2_config_t slave2_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE2_CONFIG, (uint8_t*)&slave2_config, 1);
+
+        if(ret == 0) {
+            slave2_config.slave2_rate = (uint8_t)val;
+            ret =
+                lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE2_CONFIG, (uint8_t*)&slave2_config, 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Decimation of read operation on Slave 2 starting from the
+  *         sensor hub trigger.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of slave2_rate in reg SLAVE2_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slave_2_dec_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave2_rate_t* val) {
+    lsm6ds3tr_c_slave2_config_t slave2_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE2_CONFIG, (uint8_t*)&slave2_config, 1);
+
+        if(ret == 0) {
+            switch(slave2_config.slave2_rate) {
+            case LSM6DS3TR_C_SL2_NO_DEC:
+                *val = LSM6DS3TR_C_SL2_NO_DEC;
+                break;
+
+            case LSM6DS3TR_C_SL2_DEC_2:
+                *val = LSM6DS3TR_C_SL2_DEC_2;
+                break;
+
+            case LSM6DS3TR_C_SL2_DEC_4:
+                *val = LSM6DS3TR_C_SL2_DEC_4;
+                break;
+
+            case LSM6DS3TR_C_SL2_DEC_8:
+                *val = LSM6DS3TR_C_SL2_DEC_8;
+                break;
+
+            default:
+                *val = LSM6DS3TR_C_SL2_DEC_ND;
+                break;
+            }
+
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Decimation of read operation on Slave 3 starting from the
+  *         sensor hub trigger.[set]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Change the values of slave3_rate in reg SLAVE3_CONFIG
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slave_3_dec_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave3_rate_t val) {
+    lsm6ds3tr_c_slave3_config_t slave3_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE3_CONFIG, (uint8_t*)&slave3_config, 1);
+        slave3_config.slave3_rate = (uint8_t)val;
+
+        if(ret == 0) {
+            ret =
+                lsm6ds3tr_c_write_reg(ctx, LSM6DS3TR_C_SLAVE3_CONFIG, (uint8_t*)&slave3_config, 1);
+
+            if(ret == 0) {
+                ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+            }
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @brief  Decimation of read operation on Slave 3 starting from the
+  *         sensor hub trigger.[get]
+  *
+  * @param  ctx    Read / write interface definitions
+  * @param  val    Get the values of slave3_rate in reg SLAVE3_CONFIG.
+  * @retval        Interface status (MANDATORY: return 0 -> no Error).
+  *
+  */
+int32_t lsm6ds3tr_c_sh_slave_3_dec_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave3_rate_t* val) {
+    lsm6ds3tr_c_slave3_config_t slave3_config;
+    int32_t ret;
+
+    ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_BANK_A);
+
+    if(ret == 0) {
+        ret = lsm6ds3tr_c_read_reg(ctx, LSM6DS3TR_C_SLAVE3_CONFIG, (uint8_t*)&slave3_config, 1);
+
+        if(ret == 0) {
+            switch(slave3_config.slave3_rate) {
+            case LSM6DS3TR_C_SL3_NO_DEC:
+                *val = LSM6DS3TR_C_SL3_NO_DEC;
+                break;
+
+            case LSM6DS3TR_C_SL3_DEC_2:
+                *val = LSM6DS3TR_C_SL3_DEC_2;
+                break;
+
+            case LSM6DS3TR_C_SL3_DEC_4:
+                *val = LSM6DS3TR_C_SL3_DEC_4;
+                break;
+
+            case LSM6DS3TR_C_SL3_DEC_8:
+                *val = LSM6DS3TR_C_SL3_DEC_8;
+                break;
+
+            default:
+                *val = LSM6DS3TR_C_SL3_DEC_ND;
+                break;
+            }
+
+            ret = lsm6ds3tr_c_mem_bank_set(ctx, LSM6DS3TR_C_USER_BANK);
+        }
+    }
+
+    return ret;
+}
+
+/**
+  * @}
+  *
+  */
+
+/**
+  * @}
+  *
+  */
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/

+ 2448 - 0
tracking/imu/lsm6ds3tr_c_reg.h

@@ -0,0 +1,2448 @@
+/**
+  ******************************************************************************
+  * @file    lsm6ds3tr_c_reg.h
+  * @author  Sensors Software Solution Team
+  * @brief   This file contains all the functions prototypes for the
+  *          lsm6ds3tr_c_reg.c driver.
+  ******************************************************************************
+  * @attention
+  *
+  * <h2><center>&copy; Copyright (c) 2021 STMicroelectronics.
+  * All rights reserved.</center></h2>
+  *
+  * This software component is licensed by ST under BSD 3-Clause license,
+  * the "License"; You may not use this file except in compliance with the
+  * License. You may obtain a copy of the License at:
+  *                        opensource.org/licenses/BSD-3-Clause
+  *
+  ******************************************************************************
+  */
+
+/* Define to prevent recursive inclusion -------------------------------------*/
+#ifndef LSM6DS3TR_C_DRIVER_H
+#define LSM6DS3TR_C_DRIVER_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/* Includes ------------------------------------------------------------------*/
+#include <stdint.h>
+#include <stddef.h>
+#include <math.h>
+
+/** @addtogroup LSM6DS3TR_C
+  * @{
+  *
+  */
+
+/** @defgroup  Endianness definitions
+  * @{
+  *
+  */
+
+#ifndef DRV_BYTE_ORDER
+#ifndef __BYTE_ORDER__
+
+#define DRV_LITTLE_ENDIAN 1234
+#define DRV_BIG_ENDIAN 4321
+
+/** if _BYTE_ORDER is not defined, choose the endianness of your architecture
+  * by uncommenting the define which fits your platform endianness
+  */
+//#define DRV_BYTE_ORDER    DRV_BIG_ENDIAN
+#define DRV_BYTE_ORDER DRV_LITTLE_ENDIAN
+
+#else /* defined __BYTE_ORDER__ */
+
+#define DRV_LITTLE_ENDIAN __ORDER_LITTLE_ENDIAN__
+#define DRV_BIG_ENDIAN __ORDER_BIG_ENDIAN__
+#define DRV_BYTE_ORDER __BYTE_ORDER__
+
+#endif /* __BYTE_ORDER__*/
+#endif /* DRV_BYTE_ORDER */
+
+/**
+  * @}
+  *
+  */
+
+/** @defgroup STMicroelectronics sensors common types
+  * @{
+  *
+  */
+
+#ifndef MEMS_SHARED_TYPES
+#define MEMS_SHARED_TYPES
+
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} bitwise_t;
+
+#define PROPERTY_DISABLE (0U)
+#define PROPERTY_ENABLE (1U)
+
+/** @addtogroup  Interfaces_Functions
+  * @brief       This section provide a set of functions used to read and
+  *              write a generic register of the device.
+  *              MANDATORY: return 0 -> no Error.
+  * @{
+  *
+  */
+
+typedef int32_t (*stmdev_write_ptr)(void*, uint8_t, const uint8_t*, uint16_t);
+typedef int32_t (*stmdev_read_ptr)(void*, uint8_t, uint8_t*, uint16_t);
+typedef void (*stmdev_mdelay_ptr)(uint32_t millisec);
+
+typedef struct {
+    /** Component mandatory fields **/
+    stmdev_write_ptr write_reg;
+    stmdev_read_ptr read_reg;
+    /** Component optional fields **/
+    stmdev_mdelay_ptr mdelay;
+    /** Customizable optional pointer **/
+    void* handle;
+} stmdev_ctx_t;
+
+/**
+  * @}
+  *
+  */
+
+#endif /* MEMS_SHARED_TYPES */
+
+#ifndef MEMS_UCF_SHARED_TYPES
+#define MEMS_UCF_SHARED_TYPES
+
+/** @defgroup    Generic address-data structure definition
+  * @brief       This structure is useful to load a predefined configuration
+  *              of a sensor.
+  *              You can create a sensor configuration by your own or using
+  *              Unico / Unicleo tools available on STMicroelectronics
+  *              web site.
+  *
+  * @{
+  *
+  */
+
+typedef struct {
+    uint8_t address;
+    uint8_t data;
+} ucf_line_t;
+
+/**
+  * @}
+  *
+  */
+
+#endif /* MEMS_UCF_SHARED_TYPES */
+
+/**
+  * @}
+  *
+  */
+
+/** @defgroup LSM6DS3TR_C_Infos
+  * @{
+  *
+  */
+
+/** I2C Device Address 8 bit format  if SA0=0 -> D5 if SA0=1 -> D7 **/
+#define LSM6DS3TR_C_I2C_ADD_L 0xD5U
+#define LSM6DS3TR_C_I2C_ADD_H 0xD7U
+
+/** Device Identification (Who am I) **/
+#define LSM6DS3TR_C_ID 0x6AU
+
+/**
+  * @}
+  *
+  */
+
+#define LSM6DS3TR_C_FUNC_CFG_ACCESS 0x01U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t not_used_01 : 5;
+    uint8_t func_cfg_en : 3; /* func_cfg_en + func_cfg_en_b */
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t func_cfg_en : 3; /* func_cfg_en + func_cfg_en_b */
+    uint8_t not_used_01 : 5;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_func_cfg_access_t;
+
+#define LSM6DS3TR_C_SENSOR_SYNC_TIME_FRAME 0x04U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t tph : 4;
+    uint8_t not_used_01 : 4;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t not_used_01 : 4;
+    uint8_t tph : 4;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensor_sync_time_frame_t;
+
+#define LSM6DS3TR_C_SENSOR_SYNC_RES_RATIO 0x05U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t rr : 2;
+    uint8_t not_used_01 : 6;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t not_used_01 : 6;
+    uint8_t rr : 2;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensor_sync_res_ratio_t;
+
+#define LSM6DS3TR_C_FIFO_CTRL1 0x06U
+typedef struct {
+    uint8_t fth : 8; /* + FIFO_CTRL2(fth) */
+} lsm6ds3tr_c_fifo_ctrl1_t;
+
+#define LSM6DS3TR_C_FIFO_CTRL2 0x07U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t fth : 3; /* + FIFO_CTRL1(fth) */
+    uint8_t fifo_temp_en : 1;
+    uint8_t not_used_01 : 2;
+    uint8_t timer_pedo_fifo_drdy : 1;
+    uint8_t timer_pedo_fifo_en : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t timer_pedo_fifo_en : 1;
+    uint8_t timer_pedo_fifo_drdy : 1;
+    uint8_t not_used_01 : 2;
+    uint8_t fifo_temp_en : 1;
+    uint8_t fth : 3; /* + FIFO_CTRL1(fth) */
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_fifo_ctrl2_t;
+
+#define LSM6DS3TR_C_FIFO_CTRL3 0x08U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t dec_fifo_xl : 3;
+    uint8_t dec_fifo_gyro : 3;
+    uint8_t not_used_01 : 2;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t not_used_01 : 2;
+    uint8_t dec_fifo_gyro : 3;
+    uint8_t dec_fifo_xl : 3;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_fifo_ctrl3_t;
+
+#define LSM6DS3TR_C_FIFO_CTRL4 0x09U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t dec_ds3_fifo : 3;
+    uint8_t dec_ds4_fifo : 3;
+    uint8_t only_high_data : 1;
+    uint8_t stop_on_fth : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t stop_on_fth : 1;
+    uint8_t only_high_data : 1;
+    uint8_t dec_ds4_fifo : 3;
+    uint8_t dec_ds3_fifo : 3;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_fifo_ctrl4_t;
+
+#define LSM6DS3TR_C_FIFO_CTRL5 0x0AU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t fifo_mode : 3;
+    uint8_t odr_fifo : 4;
+    uint8_t not_used_01 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t not_used_01 : 1;
+    uint8_t odr_fifo : 4;
+    uint8_t fifo_mode : 3;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_fifo_ctrl5_t;
+
+#define LSM6DS3TR_C_DRDY_PULSE_CFG_G 0x0BU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t int2_wrist_tilt : 1;
+    uint8_t not_used_01 : 6;
+    uint8_t drdy_pulsed : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t drdy_pulsed : 1;
+    uint8_t not_used_01 : 6;
+    uint8_t int2_wrist_tilt : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_drdy_pulse_cfg_g_t;
+
+#define LSM6DS3TR_C_INT1_CTRL 0x0DU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t int1_drdy_xl : 1;
+    uint8_t int1_drdy_g : 1;
+    uint8_t int1_boot : 1;
+    uint8_t int1_fth : 1;
+    uint8_t int1_fifo_ovr : 1;
+    uint8_t int1_full_flag : 1;
+    uint8_t int1_sign_mot : 1;
+    uint8_t int1_step_detector : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t int1_step_detector : 1;
+    uint8_t int1_sign_mot : 1;
+    uint8_t int1_full_flag : 1;
+    uint8_t int1_fifo_ovr : 1;
+    uint8_t int1_fth : 1;
+    uint8_t int1_boot : 1;
+    uint8_t int1_drdy_g : 1;
+    uint8_t int1_drdy_xl : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_int1_ctrl_t;
+
+#define LSM6DS3TR_C_INT2_CTRL 0x0EU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t int2_drdy_xl : 1;
+    uint8_t int2_drdy_g : 1;
+    uint8_t int2_drdy_temp : 1;
+    uint8_t int2_fth : 1;
+    uint8_t int2_fifo_ovr : 1;
+    uint8_t int2_full_flag : 1;
+    uint8_t int2_step_count_ov : 1;
+    uint8_t int2_step_delta : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t int2_step_delta : 1;
+    uint8_t int2_step_count_ov : 1;
+    uint8_t int2_full_flag : 1;
+    uint8_t int2_fifo_ovr : 1;
+    uint8_t int2_fth : 1;
+    uint8_t int2_drdy_temp : 1;
+    uint8_t int2_drdy_g : 1;
+    uint8_t int2_drdy_xl : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_int2_ctrl_t;
+
+#define LSM6DS3TR_C_WHO_AM_I 0x0FU
+#define LSM6DS3TR_C_CTRL1_XL 0x10U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bw0_xl : 1;
+    uint8_t lpf1_bw_sel : 1;
+    uint8_t fs_xl : 2;
+    uint8_t odr_xl : 4;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t odr_xl : 4;
+    uint8_t fs_xl : 2;
+    uint8_t lpf1_bw_sel : 1;
+    uint8_t bw0_xl : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_ctrl1_xl_t;
+
+#define LSM6DS3TR_C_CTRL2_G 0x11U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t not_used_01 : 1;
+    uint8_t fs_g : 3; /* fs_g + fs_125 */
+    uint8_t odr_g : 4;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t odr_g : 4;
+    uint8_t fs_g : 3; /* fs_g + fs_125 */
+    uint8_t not_used_01 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_ctrl2_g_t;
+
+#define LSM6DS3TR_C_CTRL3_C 0x12U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t sw_reset : 1;
+    uint8_t ble : 1;
+    uint8_t if_inc : 1;
+    uint8_t sim : 1;
+    uint8_t pp_od : 1;
+    uint8_t h_lactive : 1;
+    uint8_t bdu : 1;
+    uint8_t boot : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t boot : 1;
+    uint8_t bdu : 1;
+    uint8_t h_lactive : 1;
+    uint8_t pp_od : 1;
+    uint8_t sim : 1;
+    uint8_t if_inc : 1;
+    uint8_t ble : 1;
+    uint8_t sw_reset : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_ctrl3_c_t;
+
+#define LSM6DS3TR_C_CTRL4_C 0x13U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t not_used_01 : 1;
+    uint8_t lpf1_sel_g : 1;
+    uint8_t i2c_disable : 1;
+    uint8_t drdy_mask : 1;
+    uint8_t den_drdy_int1 : 1;
+    uint8_t int2_on_int1 : 1;
+    uint8_t sleep : 1;
+    uint8_t den_xl_en : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t den_xl_en : 1;
+    uint8_t sleep : 1;
+    uint8_t int2_on_int1 : 1;
+    uint8_t den_drdy_int1 : 1;
+    uint8_t drdy_mask : 1;
+    uint8_t i2c_disable : 1;
+    uint8_t lpf1_sel_g : 1;
+    uint8_t not_used_01 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_ctrl4_c_t;
+
+#define LSM6DS3TR_C_CTRL5_C 0x14U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t st_xl : 2;
+    uint8_t st_g : 2;
+    uint8_t den_lh : 1;
+    uint8_t rounding : 3;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t rounding : 3;
+    uint8_t den_lh : 1;
+    uint8_t st_g : 2;
+    uint8_t st_xl : 2;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_ctrl5_c_t;
+
+#define LSM6DS3TR_C_CTRL6_C 0x15U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t ftype : 2;
+    uint8_t not_used_01 : 1;
+    uint8_t usr_off_w : 1;
+    uint8_t xl_hm_mode : 1;
+    uint8_t den_mode : 3; /* trig_en + lvl_en + lvl2_en */
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t den_mode : 3; /* trig_en + lvl_en + lvl2_en */
+    uint8_t xl_hm_mode : 1;
+    uint8_t usr_off_w : 1;
+    uint8_t not_used_01 : 1;
+    uint8_t ftype : 2;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_ctrl6_c_t;
+
+#define LSM6DS3TR_C_CTRL7_G 0x16U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t not_used_01 : 2;
+    uint8_t rounding_status : 1;
+    uint8_t not_used_02 : 1;
+    uint8_t hpm_g : 2;
+    uint8_t hp_en_g : 1;
+    uint8_t g_hm_mode : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t g_hm_mode : 1;
+    uint8_t hp_en_g : 1;
+    uint8_t hpm_g : 2;
+    uint8_t not_used_02 : 1;
+    uint8_t rounding_status : 1;
+    uint8_t not_used_01 : 2;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_ctrl7_g_t;
+
+#define LSM6DS3TR_C_CTRL8_XL 0x17U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t low_pass_on_6d : 1;
+    uint8_t not_used_01 : 1;
+    uint8_t hp_slope_xl_en : 1;
+    uint8_t input_composite : 1;
+    uint8_t hp_ref_mode : 1;
+    uint8_t hpcf_xl : 2;
+    uint8_t lpf2_xl_en : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t lpf2_xl_en : 1;
+    uint8_t hpcf_xl : 2;
+    uint8_t hp_ref_mode : 1;
+    uint8_t input_composite : 1;
+    uint8_t hp_slope_xl_en : 1;
+    uint8_t not_used_01 : 1;
+    uint8_t low_pass_on_6d : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_ctrl8_xl_t;
+
+#define LSM6DS3TR_C_CTRL9_XL 0x18U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t not_used_01 : 2;
+    uint8_t soft_en : 1;
+    uint8_t not_used_02 : 1;
+    uint8_t den_xl_g : 1;
+    uint8_t den_z : 1;
+    uint8_t den_y : 1;
+    uint8_t den_x : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t den_x : 1;
+    uint8_t den_y : 1;
+    uint8_t den_z : 1;
+    uint8_t den_xl_g : 1;
+    uint8_t not_used_02 : 1;
+    uint8_t soft_en : 1;
+    uint8_t not_used_01 : 2;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_ctrl9_xl_t;
+
+#define LSM6DS3TR_C_CTRL10_C 0x19U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t sign_motion_en : 1;
+    uint8_t pedo_rst_step : 1;
+    uint8_t func_en : 1;
+    uint8_t tilt_en : 1;
+    uint8_t pedo_en : 1;
+    uint8_t timer_en : 1;
+    uint8_t not_used_01 : 1;
+    uint8_t wrist_tilt_en : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t wrist_tilt_en : 1;
+    uint8_t not_used_01 : 1;
+    uint8_t timer_en : 1;
+    uint8_t pedo_en : 1;
+    uint8_t tilt_en : 1;
+    uint8_t func_en : 1;
+    uint8_t pedo_rst_step : 1;
+    uint8_t sign_motion_en : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_ctrl10_c_t;
+
+#define LSM6DS3TR_C_MASTER_CONFIG 0x1AU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t master_on : 1;
+    uint8_t iron_en : 1;
+    uint8_t pass_through_mode : 1;
+    uint8_t pull_up_en : 1;
+    uint8_t start_config : 1;
+    uint8_t not_used_01 : 1;
+    uint8_t data_valid_sel_fifo : 1;
+    uint8_t drdy_on_int1 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t drdy_on_int1 : 1;
+    uint8_t data_valid_sel_fifo : 1;
+    uint8_t not_used_01 : 1;
+    uint8_t start_config : 1;
+    uint8_t pull_up_en : 1;
+    uint8_t pass_through_mode : 1;
+    uint8_t iron_en : 1;
+    uint8_t master_on : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_master_config_t;
+
+#define LSM6DS3TR_C_WAKE_UP_SRC 0x1BU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t z_wu : 1;
+    uint8_t y_wu : 1;
+    uint8_t x_wu : 1;
+    uint8_t wu_ia : 1;
+    uint8_t sleep_state_ia : 1;
+    uint8_t ff_ia : 1;
+    uint8_t not_used_01 : 2;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t not_used_01 : 2;
+    uint8_t ff_ia : 1;
+    uint8_t sleep_state_ia : 1;
+    uint8_t wu_ia : 1;
+    uint8_t x_wu : 1;
+    uint8_t y_wu : 1;
+    uint8_t z_wu : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_wake_up_src_t;
+
+#define LSM6DS3TR_C_TAP_SRC 0x1CU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t z_tap : 1;
+    uint8_t y_tap : 1;
+    uint8_t x_tap : 1;
+    uint8_t tap_sign : 1;
+    uint8_t double_tap : 1;
+    uint8_t single_tap : 1;
+    uint8_t tap_ia : 1;
+    uint8_t not_used_01 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t not_used_01 : 1;
+    uint8_t tap_ia : 1;
+    uint8_t single_tap : 1;
+    uint8_t double_tap : 1;
+    uint8_t tap_sign : 1;
+    uint8_t x_tap : 1;
+    uint8_t y_tap : 1;
+    uint8_t z_tap : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_tap_src_t;
+
+#define LSM6DS3TR_C_D6D_SRC 0x1DU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t xl : 1;
+    uint8_t xh : 1;
+    uint8_t yl : 1;
+    uint8_t yh : 1;
+    uint8_t zl : 1;
+    uint8_t zh : 1;
+    uint8_t d6d_ia : 1;
+    uint8_t den_drdy : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t den_drdy : 1;
+    uint8_t d6d_ia : 1;
+    uint8_t zh : 1;
+    uint8_t zl : 1;
+    uint8_t yh : 1;
+    uint8_t yl : 1;
+    uint8_t xh : 1;
+    uint8_t xl : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_d6d_src_t;
+
+#define LSM6DS3TR_C_STATUS_REG 0x1EU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t xlda : 1;
+    uint8_t gda : 1;
+    uint8_t tda : 1;
+    uint8_t not_used_01 : 5;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t not_used_01 : 5;
+    uint8_t tda : 1;
+    uint8_t gda : 1;
+    uint8_t xlda : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_status_reg_t;
+
+#define LSM6DS3TR_C_OUT_TEMP_L 0x20U
+#define LSM6DS3TR_C_OUT_TEMP_H 0x21U
+#define LSM6DS3TR_C_OUTX_L_G 0x22U
+#define LSM6DS3TR_C_OUTX_H_G 0x23U
+#define LSM6DS3TR_C_OUTY_L_G 0x24U
+#define LSM6DS3TR_C_OUTY_H_G 0x25U
+#define LSM6DS3TR_C_OUTZ_L_G 0x26U
+#define LSM6DS3TR_C_OUTZ_H_G 0x27U
+#define LSM6DS3TR_C_OUTX_L_XL 0x28U
+#define LSM6DS3TR_C_OUTX_H_XL 0x29U
+#define LSM6DS3TR_C_OUTY_L_XL 0x2AU
+#define LSM6DS3TR_C_OUTY_H_XL 0x2BU
+#define LSM6DS3TR_C_OUTZ_L_XL 0x2CU
+#define LSM6DS3TR_C_OUTZ_H_XL 0x2DU
+#define LSM6DS3TR_C_SENSORHUB1_REG 0x2EU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub1_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB2_REG 0x2FU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub2_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB3_REG 0x30U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub3_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB4_REG 0x31U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub4_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB5_REG 0x32U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub5_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB6_REG 0x33U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub6_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB7_REG 0x34U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub7_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB8_REG 0x35U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub8_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB9_REG 0x36U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub9_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB10_REG 0x37U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub10_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB11_REG 0x38U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub11_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB12_REG 0x39U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub12_reg_t;
+
+#define LSM6DS3TR_C_FIFO_STATUS1 0x3AU
+typedef struct {
+    uint8_t diff_fifo : 8; /* + FIFO_STATUS2(diff_fifo) */
+} lsm6ds3tr_c_fifo_status1_t;
+
+#define LSM6DS3TR_C_FIFO_STATUS2 0x3BU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t diff_fifo : 3; /* + FIFO_STATUS1(diff_fifo) */
+    uint8_t not_used_01 : 1;
+    uint8_t fifo_empty : 1;
+    uint8_t fifo_full_smart : 1;
+    uint8_t over_run : 1;
+    uint8_t waterm : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t waterm : 1;
+    uint8_t over_run : 1;
+    uint8_t fifo_full_smart : 1;
+    uint8_t fifo_empty : 1;
+    uint8_t not_used_01 : 1;
+    uint8_t diff_fifo : 3; /* + FIFO_STATUS1(diff_fifo) */
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_fifo_status2_t;
+
+#define LSM6DS3TR_C_FIFO_STATUS3 0x3CU
+typedef struct {
+    uint8_t fifo_pattern : 8; /* + FIFO_STATUS4(fifo_pattern) */
+} lsm6ds3tr_c_fifo_status3_t;
+
+#define LSM6DS3TR_C_FIFO_STATUS4 0x3DU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t fifo_pattern : 2; /* + FIFO_STATUS3(fifo_pattern) */
+    uint8_t not_used_01 : 6;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t not_used_01 : 6;
+    uint8_t fifo_pattern : 2; /* + FIFO_STATUS3(fifo_pattern) */
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_fifo_status4_t;
+
+#define LSM6DS3TR_C_FIFO_DATA_OUT_L 0x3EU
+#define LSM6DS3TR_C_FIFO_DATA_OUT_H 0x3FU
+#define LSM6DS3TR_C_TIMESTAMP0_REG 0x40U
+#define LSM6DS3TR_C_TIMESTAMP1_REG 0x41U
+#define LSM6DS3TR_C_TIMESTAMP2_REG 0x42U
+#define LSM6DS3TR_C_STEP_TIMESTAMP_L 0x49U
+#define LSM6DS3TR_C_STEP_TIMESTAMP_H 0x4AU
+#define LSM6DS3TR_C_STEP_COUNTER_L 0x4BU
+#define LSM6DS3TR_C_STEP_COUNTER_H 0x4CU
+
+#define LSM6DS3TR_C_SENSORHUB13_REG 0x4DU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub13_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB14_REG 0x4EU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub14_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB15_REG 0x4FU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub15_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB16_REG 0x50U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub16_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB17_REG 0x51U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub17_reg_t;
+
+#define LSM6DS3TR_C_SENSORHUB18_REG 0x52U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t bit0 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit7 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t bit7 : 1;
+    uint8_t bit6 : 1;
+    uint8_t bit5 : 1;
+    uint8_t bit4 : 1;
+    uint8_t bit3 : 1;
+    uint8_t bit2 : 1;
+    uint8_t bit1 : 1;
+    uint8_t bit0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_sensorhub18_reg_t;
+
+#define LSM6DS3TR_C_FUNC_SRC1 0x53U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t sensorhub_end_op : 1;
+    uint8_t si_end_op : 1;
+    uint8_t hi_fail : 1;
+    uint8_t step_overflow : 1;
+    uint8_t step_detected : 1;
+    uint8_t tilt_ia : 1;
+    uint8_t sign_motion_ia : 1;
+    uint8_t step_count_delta_ia : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t step_count_delta_ia : 1;
+    uint8_t sign_motion_ia : 1;
+    uint8_t tilt_ia : 1;
+    uint8_t step_detected : 1;
+    uint8_t step_overflow : 1;
+    uint8_t hi_fail : 1;
+    uint8_t si_end_op : 1;
+    uint8_t sensorhub_end_op : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_func_src1_t;
+
+#define LSM6DS3TR_C_FUNC_SRC2 0x54U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t wrist_tilt_ia : 1;
+    uint8_t not_used_01 : 2;
+    uint8_t slave0_nack : 1;
+    uint8_t slave1_nack : 1;
+    uint8_t slave2_nack : 1;
+    uint8_t slave3_nack : 1;
+    uint8_t not_used_02 : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t not_used_02 : 1;
+    uint8_t slave3_nack : 1;
+    uint8_t slave2_nack : 1;
+    uint8_t slave1_nack : 1;
+    uint8_t slave0_nack : 1;
+    uint8_t not_used_01 : 2;
+    uint8_t wrist_tilt_ia : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_func_src2_t;
+
+#define LSM6DS3TR_C_WRIST_TILT_IA 0x55U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t not_used_01 : 2;
+    uint8_t wrist_tilt_ia_zneg : 1;
+    uint8_t wrist_tilt_ia_zpos : 1;
+    uint8_t wrist_tilt_ia_yneg : 1;
+    uint8_t wrist_tilt_ia_ypos : 1;
+    uint8_t wrist_tilt_ia_xneg : 1;
+    uint8_t wrist_tilt_ia_xpos : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t wrist_tilt_ia_xpos : 1;
+    uint8_t wrist_tilt_ia_xneg : 1;
+    uint8_t wrist_tilt_ia_ypos : 1;
+    uint8_t wrist_tilt_ia_yneg : 1;
+    uint8_t wrist_tilt_ia_zpos : 1;
+    uint8_t wrist_tilt_ia_zneg : 1;
+    uint8_t not_used_01 : 2;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_wrist_tilt_ia_t;
+
+#define LSM6DS3TR_C_TAP_CFG 0x58U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t lir : 1;
+    uint8_t tap_z_en : 1;
+    uint8_t tap_y_en : 1;
+    uint8_t tap_x_en : 1;
+    uint8_t slope_fds : 1;
+    uint8_t inact_en : 2;
+    uint8_t interrupts_enable : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t interrupts_enable : 1;
+    uint8_t inact_en : 2;
+    uint8_t slope_fds : 1;
+    uint8_t tap_x_en : 1;
+    uint8_t tap_y_en : 1;
+    uint8_t tap_z_en : 1;
+    uint8_t lir : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_tap_cfg_t;
+
+#define LSM6DS3TR_C_TAP_THS_6D 0x59U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t tap_ths : 5;
+    uint8_t sixd_ths : 2;
+    uint8_t d4d_en : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t d4d_en : 1;
+    uint8_t sixd_ths : 2;
+    uint8_t tap_ths : 5;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_tap_ths_6d_t;
+
+#define LSM6DS3TR_C_INT_DUR2 0x5AU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t shock : 2;
+    uint8_t quiet : 2;
+    uint8_t dur : 4;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t dur : 4;
+    uint8_t quiet : 2;
+    uint8_t shock : 2;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_int_dur2_t;
+
+#define LSM6DS3TR_C_WAKE_UP_THS 0x5BU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t wk_ths : 6;
+    uint8_t not_used_01 : 1;
+    uint8_t single_double_tap : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t single_double_tap : 1;
+    uint8_t not_used_01 : 1;
+    uint8_t wk_ths : 6;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_wake_up_ths_t;
+
+#define LSM6DS3TR_C_WAKE_UP_DUR 0x5CU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t sleep_dur : 4;
+    uint8_t timer_hr : 1;
+    uint8_t wake_dur : 2;
+    uint8_t ff_dur : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t ff_dur : 1;
+    uint8_t wake_dur : 2;
+    uint8_t timer_hr : 1;
+    uint8_t sleep_dur : 4;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_wake_up_dur_t;
+
+#define LSM6DS3TR_C_FREE_FALL 0x5DU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t ff_ths : 3;
+    uint8_t ff_dur : 5;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t ff_dur : 5;
+    uint8_t ff_ths : 3;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_free_fall_t;
+
+#define LSM6DS3TR_C_MD1_CFG 0x5EU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t int1_timer : 1;
+    uint8_t int1_tilt : 1;
+    uint8_t int1_6d : 1;
+    uint8_t int1_double_tap : 1;
+    uint8_t int1_ff : 1;
+    uint8_t int1_wu : 1;
+    uint8_t int1_single_tap : 1;
+    uint8_t int1_inact_state : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t int1_inact_state : 1;
+    uint8_t int1_single_tap : 1;
+    uint8_t int1_wu : 1;
+    uint8_t int1_ff : 1;
+    uint8_t int1_double_tap : 1;
+    uint8_t int1_6d : 1;
+    uint8_t int1_tilt : 1;
+    uint8_t int1_timer : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_md1_cfg_t;
+
+#define LSM6DS3TR_C_MD2_CFG 0x5FU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t int2_iron : 1;
+    uint8_t int2_tilt : 1;
+    uint8_t int2_6d : 1;
+    uint8_t int2_double_tap : 1;
+    uint8_t int2_ff : 1;
+    uint8_t int2_wu : 1;
+    uint8_t int2_single_tap : 1;
+    uint8_t int2_inact_state : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t int2_inact_state : 1;
+    uint8_t int2_single_tap : 1;
+    uint8_t int2_wu : 1;
+    uint8_t int2_ff : 1;
+    uint8_t int2_double_tap : 1;
+    uint8_t int2_6d : 1;
+    uint8_t int2_tilt : 1;
+    uint8_t int2_iron : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_md2_cfg_t;
+
+#define LSM6DS3TR_C_MASTER_CMD_CODE 0x60U
+typedef struct {
+    uint8_t master_cmd_code : 8;
+} lsm6ds3tr_c_master_cmd_code_t;
+
+#define LSM6DS3TR_C_SENS_SYNC_SPI_ERROR_CODE 0x61U
+typedef struct {
+    uint8_t error_code : 8;
+} lsm6ds3tr_c_sens_sync_spi_error_code_t;
+
+#define LSM6DS3TR_C_OUT_MAG_RAW_X_L 0x66U
+#define LSM6DS3TR_C_OUT_MAG_RAW_X_H 0x67U
+#define LSM6DS3TR_C_OUT_MAG_RAW_Y_L 0x68U
+#define LSM6DS3TR_C_OUT_MAG_RAW_Y_H 0x69U
+#define LSM6DS3TR_C_OUT_MAG_RAW_Z_L 0x6AU
+#define LSM6DS3TR_C_OUT_MAG_RAW_Z_H 0x6BU
+#define LSM6DS3TR_C_X_OFS_USR 0x73U
+#define LSM6DS3TR_C_Y_OFS_USR 0x74U
+#define LSM6DS3TR_C_Z_OFS_USR 0x75U
+#define LSM6DS3TR_C_SLV0_ADD 0x02U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t rw_0 : 1;
+    uint8_t slave0_add : 7;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t slave0_add : 7;
+    uint8_t rw_0 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_slv0_add_t;
+
+#define LSM6DS3TR_C_SLV0_SUBADD 0x03U
+typedef struct {
+    uint8_t slave0_reg : 8;
+} lsm6ds3tr_c_slv0_subadd_t;
+
+#define LSM6DS3TR_C_SLAVE0_CONFIG 0x04U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t slave0_numop : 3;
+    uint8_t src_mode : 1;
+    uint8_t aux_sens_on : 2;
+    uint8_t slave0_rate : 2;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t slave0_rate : 2;
+    uint8_t aux_sens_on : 2;
+    uint8_t src_mode : 1;
+    uint8_t slave0_numop : 3;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_slave0_config_t;
+
+#define LSM6DS3TR_C_SLV1_ADD 0x05U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t r_1 : 1;
+    uint8_t slave1_add : 7;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t slave1_add : 7;
+    uint8_t r_1 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_slv1_add_t;
+
+#define LSM6DS3TR_C_SLV1_SUBADD 0x06U
+typedef struct {
+    uint8_t slave1_reg : 8;
+} lsm6ds3tr_c_slv1_subadd_t;
+
+#define LSM6DS3TR_C_SLAVE1_CONFIG 0x07U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t slave1_numop : 3;
+    uint8_t not_used_01 : 2;
+    uint8_t write_once : 1;
+    uint8_t slave1_rate : 2;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t slave1_rate : 2;
+    uint8_t write_once : 1;
+    uint8_t not_used_01 : 2;
+    uint8_t slave1_numop : 3;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_slave1_config_t;
+
+#define LSM6DS3TR_C_SLV2_ADD 0x08U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t r_2 : 1;
+    uint8_t slave2_add : 7;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t slave2_add : 7;
+    uint8_t r_2 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_slv2_add_t;
+
+#define LSM6DS3TR_C_SLV2_SUBADD 0x09U
+typedef struct {
+    uint8_t slave2_reg : 8;
+} lsm6ds3tr_c_slv2_subadd_t;
+
+#define LSM6DS3TR_C_SLAVE2_CONFIG 0x0AU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t slave2_numop : 3;
+    uint8_t not_used_01 : 3;
+    uint8_t slave2_rate : 2;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t slave2_rate : 2;
+    uint8_t not_used_01 : 3;
+    uint8_t slave2_numop : 3;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_slave2_config_t;
+
+#define LSM6DS3TR_C_SLV3_ADD 0x0BU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t r_3 : 1;
+    uint8_t slave3_add : 7;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t slave3_add : 7;
+    uint8_t r_3 : 1;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_slv3_add_t;
+
+#define LSM6DS3TR_C_SLV3_SUBADD 0x0CU
+typedef struct {
+    uint8_t slave3_reg : 8;
+} lsm6ds3tr_c_slv3_subadd_t;
+
+#define LSM6DS3TR_C_SLAVE3_CONFIG 0x0DU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t slave3_numop : 3;
+    uint8_t not_used_01 : 3;
+    uint8_t slave3_rate : 2;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t slave3_rate : 2;
+    uint8_t not_used_01 : 3;
+    uint8_t slave3_numop : 3;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_slave3_config_t;
+
+#define LSM6DS3TR_C_DATAWRITE_SRC_MODE_SUB_SLV0 0x0EU
+typedef struct {
+    uint8_t slave_dataw : 8;
+} lsm6ds3tr_c_datawrite_src_mode_sub_slv0_t;
+
+#define LSM6DS3TR_C_CONFIG_PEDO_THS_MIN 0x0FU
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t ths_min : 5;
+    uint8_t not_used_01 : 2;
+    uint8_t pedo_fs : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t pedo_fs : 1;
+    uint8_t not_used_01 : 2;
+    uint8_t ths_min : 5;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_config_pedo_ths_min_t;
+
+#define LSM6DS3TR_C_SM_THS 0x13U
+#define LSM6DS3TR_C_PEDO_DEB_REG 0x14U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t deb_step : 3;
+    uint8_t deb_time : 5;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t deb_time : 5;
+    uint8_t deb_step : 3;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_pedo_deb_reg_t;
+
+#define LSM6DS3TR_C_STEP_COUNT_DELTA 0x15U
+#define LSM6DS3TR_C_MAG_SI_XX 0x24U
+#define LSM6DS3TR_C_MAG_SI_XY 0x25U
+#define LSM6DS3TR_C_MAG_SI_XZ 0x26U
+#define LSM6DS3TR_C_MAG_SI_YX 0x27U
+#define LSM6DS3TR_C_MAG_SI_YY 0x28U
+#define LSM6DS3TR_C_MAG_SI_YZ 0x29U
+#define LSM6DS3TR_C_MAG_SI_ZX 0x2AU
+#define LSM6DS3TR_C_MAG_SI_ZY 0x2BU
+#define LSM6DS3TR_C_MAG_SI_ZZ 0x2CU
+#define LSM6DS3TR_C_MAG_OFFX_L 0x2DU
+#define LSM6DS3TR_C_MAG_OFFX_H 0x2EU
+#define LSM6DS3TR_C_MAG_OFFY_L 0x2FU
+#define LSM6DS3TR_C_MAG_OFFY_H 0x30U
+#define LSM6DS3TR_C_MAG_OFFZ_L 0x31U
+#define LSM6DS3TR_C_MAG_OFFZ_H 0x32U
+#define LSM6DS3TR_C_A_WRIST_TILT_LAT 0x50U
+#define LSM6DS3TR_C_A_WRIST_TILT_THS 0x54U
+#define LSM6DS3TR_C_A_WRIST_TILT_MASK 0x59U
+typedef struct {
+#if DRV_BYTE_ORDER == DRV_LITTLE_ENDIAN
+    uint8_t not_used_01 : 2;
+    uint8_t wrist_tilt_mask_zneg : 1;
+    uint8_t wrist_tilt_mask_zpos : 1;
+    uint8_t wrist_tilt_mask_yneg : 1;
+    uint8_t wrist_tilt_mask_ypos : 1;
+    uint8_t wrist_tilt_mask_xneg : 1;
+    uint8_t wrist_tilt_mask_xpos : 1;
+#elif DRV_BYTE_ORDER == DRV_BIG_ENDIAN
+    uint8_t wrist_tilt_mask_xpos : 1;
+    uint8_t wrist_tilt_mask_xneg : 1;
+    uint8_t wrist_tilt_mask_ypos : 1;
+    uint8_t wrist_tilt_mask_yneg : 1;
+    uint8_t wrist_tilt_mask_zpos : 1;
+    uint8_t wrist_tilt_mask_zneg : 1;
+    uint8_t not_used_01 : 2;
+#endif /* DRV_BYTE_ORDER */
+} lsm6ds3tr_c_a_wrist_tilt_mask_t;
+
+/**
+  * @defgroup LSM6DS3TR_C_Register_Union
+  * @brief    This union group all the registers having a bit-field
+  *           description.
+  *           This union is useful but it's not needed by the driver.
+  *
+  *           REMOVING this union you are compliant with:
+  *           MISRA-C 2012 [Rule 19.2] -> " Union are not allowed "
+  *
+  * @{
+  *
+  */
+typedef union {
+    lsm6ds3tr_c_func_cfg_access_t func_cfg_access;
+    lsm6ds3tr_c_sensor_sync_time_frame_t sensor_sync_time_frame;
+    lsm6ds3tr_c_sensor_sync_res_ratio_t sensor_sync_res_ratio;
+    lsm6ds3tr_c_fifo_ctrl1_t fifo_ctrl1;
+    lsm6ds3tr_c_fifo_ctrl2_t fifo_ctrl2;
+    lsm6ds3tr_c_fifo_ctrl3_t fifo_ctrl3;
+    lsm6ds3tr_c_fifo_ctrl4_t fifo_ctrl4;
+    lsm6ds3tr_c_fifo_ctrl5_t fifo_ctrl5;
+    lsm6ds3tr_c_drdy_pulse_cfg_g_t drdy_pulse_cfg_g;
+    lsm6ds3tr_c_int1_ctrl_t int1_ctrl;
+    lsm6ds3tr_c_int2_ctrl_t int2_ctrl;
+    lsm6ds3tr_c_ctrl1_xl_t ctrl1_xl;
+    lsm6ds3tr_c_ctrl2_g_t ctrl2_g;
+    lsm6ds3tr_c_ctrl3_c_t ctrl3_c;
+    lsm6ds3tr_c_ctrl4_c_t ctrl4_c;
+    lsm6ds3tr_c_ctrl5_c_t ctrl5_c;
+    lsm6ds3tr_c_ctrl6_c_t ctrl6_c;
+    lsm6ds3tr_c_ctrl7_g_t ctrl7_g;
+    lsm6ds3tr_c_ctrl8_xl_t ctrl8_xl;
+    lsm6ds3tr_c_ctrl9_xl_t ctrl9_xl;
+    lsm6ds3tr_c_ctrl10_c_t ctrl10_c;
+    lsm6ds3tr_c_master_config_t master_config;
+    lsm6ds3tr_c_wake_up_src_t wake_up_src;
+    lsm6ds3tr_c_tap_src_t tap_src;
+    lsm6ds3tr_c_d6d_src_t d6d_src;
+    lsm6ds3tr_c_status_reg_t status_reg;
+    lsm6ds3tr_c_sensorhub1_reg_t sensorhub1_reg;
+    lsm6ds3tr_c_sensorhub2_reg_t sensorhub2_reg;
+    lsm6ds3tr_c_sensorhub3_reg_t sensorhub3_reg;
+    lsm6ds3tr_c_sensorhub4_reg_t sensorhub4_reg;
+    lsm6ds3tr_c_sensorhub5_reg_t sensorhub5_reg;
+    lsm6ds3tr_c_sensorhub6_reg_t sensorhub6_reg;
+    lsm6ds3tr_c_sensorhub7_reg_t sensorhub7_reg;
+    lsm6ds3tr_c_sensorhub8_reg_t sensorhub8_reg;
+    lsm6ds3tr_c_sensorhub9_reg_t sensorhub9_reg;
+    lsm6ds3tr_c_sensorhub10_reg_t sensorhub10_reg;
+    lsm6ds3tr_c_sensorhub11_reg_t sensorhub11_reg;
+    lsm6ds3tr_c_sensorhub12_reg_t sensorhub12_reg;
+    lsm6ds3tr_c_fifo_status1_t fifo_status1;
+    lsm6ds3tr_c_fifo_status2_t fifo_status2;
+    lsm6ds3tr_c_fifo_status3_t fifo_status3;
+    lsm6ds3tr_c_fifo_status4_t fifo_status4;
+    lsm6ds3tr_c_sensorhub13_reg_t sensorhub13_reg;
+    lsm6ds3tr_c_sensorhub14_reg_t sensorhub14_reg;
+    lsm6ds3tr_c_sensorhub15_reg_t sensorhub15_reg;
+    lsm6ds3tr_c_sensorhub16_reg_t sensorhub16_reg;
+    lsm6ds3tr_c_sensorhub17_reg_t sensorhub17_reg;
+    lsm6ds3tr_c_sensorhub18_reg_t sensorhub18_reg;
+    lsm6ds3tr_c_func_src1_t func_src1;
+    lsm6ds3tr_c_func_src2_t func_src2;
+    lsm6ds3tr_c_wrist_tilt_ia_t wrist_tilt_ia;
+    lsm6ds3tr_c_tap_cfg_t tap_cfg;
+    lsm6ds3tr_c_tap_ths_6d_t tap_ths_6d;
+    lsm6ds3tr_c_int_dur2_t int_dur2;
+    lsm6ds3tr_c_wake_up_ths_t wake_up_ths;
+    lsm6ds3tr_c_wake_up_dur_t wake_up_dur;
+    lsm6ds3tr_c_free_fall_t free_fall;
+    lsm6ds3tr_c_md1_cfg_t md1_cfg;
+    lsm6ds3tr_c_md2_cfg_t md2_cfg;
+    lsm6ds3tr_c_master_cmd_code_t master_cmd_code;
+    lsm6ds3tr_c_sens_sync_spi_error_code_t sens_sync_spi_error_code;
+    lsm6ds3tr_c_slv0_add_t slv0_add;
+    lsm6ds3tr_c_slv0_subadd_t slv0_subadd;
+    lsm6ds3tr_c_slave0_config_t slave0_config;
+    lsm6ds3tr_c_slv1_add_t slv1_add;
+    lsm6ds3tr_c_slv1_subadd_t slv1_subadd;
+    lsm6ds3tr_c_slave1_config_t slave1_config;
+    lsm6ds3tr_c_slv2_add_t slv2_add;
+    lsm6ds3tr_c_slv2_subadd_t slv2_subadd;
+    lsm6ds3tr_c_slave2_config_t slave2_config;
+    lsm6ds3tr_c_slv3_add_t slv3_add;
+    lsm6ds3tr_c_slv3_subadd_t slv3_subadd;
+    lsm6ds3tr_c_slave3_config_t slave3_config;
+    lsm6ds3tr_c_datawrite_src_mode_sub_slv0_t datawrite_src_mode_sub_slv0;
+    lsm6ds3tr_c_config_pedo_ths_min_t config_pedo_ths_min;
+    lsm6ds3tr_c_pedo_deb_reg_t pedo_deb_reg;
+    lsm6ds3tr_c_a_wrist_tilt_mask_t a_wrist_tilt_mask;
+    bitwise_t bitwise;
+    uint8_t byte;
+} lsm6ds3tr_c_reg_t;
+
+/**
+  * @}
+  *
+  */
+
+int32_t lsm6ds3tr_c_read_reg(stmdev_ctx_t* ctx, uint8_t reg, uint8_t* data, uint16_t len);
+int32_t lsm6ds3tr_c_write_reg(stmdev_ctx_t* ctx, uint8_t reg, uint8_t* data, uint16_t len);
+
+float_t lsm6ds3tr_c_from_fs2g_to_mg(int16_t lsb);
+float_t lsm6ds3tr_c_from_fs4g_to_mg(int16_t lsb);
+float_t lsm6ds3tr_c_from_fs8g_to_mg(int16_t lsb);
+float_t lsm6ds3tr_c_from_fs16g_to_mg(int16_t lsb);
+
+float_t lsm6ds3tr_c_from_fs125dps_to_mdps(int16_t lsb);
+float_t lsm6ds3tr_c_from_fs250dps_to_mdps(int16_t lsb);
+float_t lsm6ds3tr_c_from_fs500dps_to_mdps(int16_t lsb);
+float_t lsm6ds3tr_c_from_fs1000dps_to_mdps(int16_t lsb);
+float_t lsm6ds3tr_c_from_fs2000dps_to_mdps(int16_t lsb);
+
+float_t lsm6ds3tr_c_from_lsb_to_celsius(int16_t lsb);
+
+typedef enum {
+    LSM6DS3TR_C_2g = 0,
+    LSM6DS3TR_C_16g = 1,
+    LSM6DS3TR_C_4g = 2,
+    LSM6DS3TR_C_8g = 3,
+    LSM6DS3TR_C_XL_FS_ND = 4, /* ERROR CODE */
+} lsm6ds3tr_c_fs_xl_t;
+int32_t lsm6ds3tr_c_xl_full_scale_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_fs_xl_t val);
+int32_t lsm6ds3tr_c_xl_full_scale_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_fs_xl_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_XL_ODR_OFF = 0,
+    LSM6DS3TR_C_XL_ODR_12Hz5 = 1,
+    LSM6DS3TR_C_XL_ODR_26Hz = 2,
+    LSM6DS3TR_C_XL_ODR_52Hz = 3,
+    LSM6DS3TR_C_XL_ODR_104Hz = 4,
+    LSM6DS3TR_C_XL_ODR_208Hz = 5,
+    LSM6DS3TR_C_XL_ODR_416Hz = 6,
+    LSM6DS3TR_C_XL_ODR_833Hz = 7,
+    LSM6DS3TR_C_XL_ODR_1k66Hz = 8,
+    LSM6DS3TR_C_XL_ODR_3k33Hz = 9,
+    LSM6DS3TR_C_XL_ODR_6k66Hz = 10,
+    LSM6DS3TR_C_XL_ODR_1Hz6 = 11,
+    LSM6DS3TR_C_XL_ODR_ND = 12, /* ERROR CODE */
+} lsm6ds3tr_c_odr_xl_t;
+int32_t lsm6ds3tr_c_xl_data_rate_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_xl_t val);
+int32_t lsm6ds3tr_c_xl_data_rate_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_xl_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_250dps = 0,
+    LSM6DS3TR_C_125dps = 1,
+    LSM6DS3TR_C_500dps = 2,
+    LSM6DS3TR_C_1000dps = 4,
+    LSM6DS3TR_C_2000dps = 6,
+    LSM6DS3TR_C_GY_FS_ND = 7, /* ERROR CODE */
+} lsm6ds3tr_c_fs_g_t;
+int32_t lsm6ds3tr_c_gy_full_scale_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_fs_g_t val);
+int32_t lsm6ds3tr_c_gy_full_scale_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_fs_g_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_GY_ODR_OFF = 0,
+    LSM6DS3TR_C_GY_ODR_12Hz5 = 1,
+    LSM6DS3TR_C_GY_ODR_26Hz = 2,
+    LSM6DS3TR_C_GY_ODR_52Hz = 3,
+    LSM6DS3TR_C_GY_ODR_104Hz = 4,
+    LSM6DS3TR_C_GY_ODR_208Hz = 5,
+    LSM6DS3TR_C_GY_ODR_416Hz = 6,
+    LSM6DS3TR_C_GY_ODR_833Hz = 7,
+    LSM6DS3TR_C_GY_ODR_1k66Hz = 8,
+    LSM6DS3TR_C_GY_ODR_3k33Hz = 9,
+    LSM6DS3TR_C_GY_ODR_6k66Hz = 10,
+    LSM6DS3TR_C_GY_ODR_ND = 11, /* ERROR CODE */
+} lsm6ds3tr_c_odr_g_t;
+int32_t lsm6ds3tr_c_gy_data_rate_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_g_t val);
+int32_t lsm6ds3tr_c_gy_data_rate_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_g_t* val);
+
+int32_t lsm6ds3tr_c_block_data_update_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_block_data_update_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_LSb_1mg = 0,
+    LSM6DS3TR_C_LSb_16mg = 1,
+    LSM6DS3TR_C_WEIGHT_ND = 2,
+} lsm6ds3tr_c_usr_off_w_t;
+int32_t lsm6ds3tr_c_xl_offset_weight_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_usr_off_w_t val);
+int32_t lsm6ds3tr_c_xl_offset_weight_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_usr_off_w_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_XL_HIGH_PERFORMANCE = 0,
+    LSM6DS3TR_C_XL_NORMAL = 1,
+    LSM6DS3TR_C_XL_PW_MODE_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_xl_hm_mode_t;
+int32_t lsm6ds3tr_c_xl_power_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_xl_hm_mode_t val);
+int32_t lsm6ds3tr_c_xl_power_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_xl_hm_mode_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_STAT_RND_DISABLE = 0,
+    LSM6DS3TR_C_STAT_RND_ENABLE = 1,
+    LSM6DS3TR_C_STAT_RND_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_rounding_status_t;
+int32_t lsm6ds3tr_c_rounding_on_status_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_rounding_status_t val);
+int32_t lsm6ds3tr_c_rounding_on_status_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_rounding_status_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_GY_HIGH_PERFORMANCE = 0,
+    LSM6DS3TR_C_GY_NORMAL = 1,
+    LSM6DS3TR_C_GY_PW_MODE_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_g_hm_mode_t;
+int32_t lsm6ds3tr_c_gy_power_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_g_hm_mode_t val);
+int32_t lsm6ds3tr_c_gy_power_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_g_hm_mode_t* val);
+
+typedef struct {
+    lsm6ds3tr_c_wake_up_src_t wake_up_src;
+    lsm6ds3tr_c_tap_src_t tap_src;
+    lsm6ds3tr_c_d6d_src_t d6d_src;
+    lsm6ds3tr_c_status_reg_t status_reg;
+    lsm6ds3tr_c_func_src1_t func_src1;
+    lsm6ds3tr_c_func_src2_t func_src2;
+    lsm6ds3tr_c_wrist_tilt_ia_t wrist_tilt_ia;
+    lsm6ds3tr_c_a_wrist_tilt_mask_t a_wrist_tilt_mask;
+} lsm6ds3tr_c_all_sources_t;
+int32_t lsm6ds3tr_c_all_sources_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_all_sources_t* val);
+
+int32_t lsm6ds3tr_c_status_reg_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_status_reg_t* val);
+
+int32_t lsm6ds3tr_c_xl_flag_data_ready_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_gy_flag_data_ready_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_temp_flag_data_ready_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_xl_usr_offset_set(stmdev_ctx_t* ctx, uint8_t* buff);
+int32_t lsm6ds3tr_c_xl_usr_offset_get(stmdev_ctx_t* ctx, uint8_t* buff);
+int32_t lsm6ds3tr_c_timestamp_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_timestamp_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_LSB_6ms4 = 0,
+    LSM6DS3TR_C_LSB_25us = 1,
+    LSM6DS3TR_C_TS_RES_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_timer_hr_t;
+int32_t lsm6ds3tr_c_timestamp_res_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_timer_hr_t val);
+int32_t lsm6ds3tr_c_timestamp_res_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_timer_hr_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_ROUND_DISABLE = 0,
+    LSM6DS3TR_C_ROUND_XL = 1,
+    LSM6DS3TR_C_ROUND_GY = 2,
+    LSM6DS3TR_C_ROUND_GY_XL = 3,
+    LSM6DS3TR_C_ROUND_SH1_TO_SH6 = 4,
+    LSM6DS3TR_C_ROUND_XL_SH1_TO_SH6 = 5,
+    LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH12 = 6,
+    LSM6DS3TR_C_ROUND_GY_XL_SH1_TO_SH6 = 7,
+    LSM6DS3TR_C_ROUND_OUT_ND = 8, /* ERROR CODE */
+} lsm6ds3tr_c_rounding_t;
+int32_t lsm6ds3tr_c_rounding_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_rounding_t val);
+int32_t lsm6ds3tr_c_rounding_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_rounding_t* val);
+
+int32_t lsm6ds3tr_c_temperature_raw_get(stmdev_ctx_t* ctx, int16_t* val);
+int32_t lsm6ds3tr_c_angular_rate_raw_get(stmdev_ctx_t* ctx, int16_t* val);
+int32_t lsm6ds3tr_c_acceleration_raw_get(stmdev_ctx_t* ctx, int16_t* val);
+
+int32_t lsm6ds3tr_c_mag_calibrated_raw_get(stmdev_ctx_t* ctx, int16_t* val);
+
+int32_t lsm6ds3tr_c_fifo_raw_data_get(stmdev_ctx_t* ctx, uint8_t* buffer, uint8_t len);
+
+typedef enum {
+    LSM6DS3TR_C_USER_BANK = 0,
+    LSM6DS3TR_C_BANK_A = 4,
+    LSM6DS3TR_C_BANK_B = 5,
+    LSM6DS3TR_C_BANK_ND = 6, /* ERROR CODE */
+} lsm6ds3tr_c_func_cfg_en_t;
+int32_t lsm6ds3tr_c_mem_bank_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_func_cfg_en_t val);
+int32_t lsm6ds3tr_c_mem_bank_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_func_cfg_en_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_DRDY_LATCHED = 0,
+    LSM6DS3TR_C_DRDY_PULSED = 1,
+    LSM6DS3TR_C_DRDY_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_drdy_pulsed_g_t;
+int32_t lsm6ds3tr_c_data_ready_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_drdy_pulsed_g_t val);
+int32_t lsm6ds3tr_c_data_ready_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_drdy_pulsed_g_t* val);
+
+int32_t lsm6ds3tr_c_device_id_get(stmdev_ctx_t* ctx, uint8_t* buff);
+int32_t lsm6ds3tr_c_reset_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_reset_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_LSB_AT_LOW_ADD = 0,
+    LSM6DS3TR_C_MSB_AT_LOW_ADD = 1,
+    LSM6DS3TR_C_DATA_FMT_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_ble_t;
+int32_t lsm6ds3tr_c_data_format_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_ble_t val);
+int32_t lsm6ds3tr_c_data_format_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_ble_t* val);
+
+int32_t lsm6ds3tr_c_auto_increment_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_auto_increment_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_boot_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_boot_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_XL_ST_DISABLE = 0,
+    LSM6DS3TR_C_XL_ST_POSITIVE = 1,
+    LSM6DS3TR_C_XL_ST_NEGATIVE = 2,
+    LSM6DS3TR_C_XL_ST_ND = 3, /* ERROR CODE */
+} lsm6ds3tr_c_st_xl_t;
+int32_t lsm6ds3tr_c_xl_self_test_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_st_xl_t val);
+int32_t lsm6ds3tr_c_xl_self_test_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_st_xl_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_GY_ST_DISABLE = 0,
+    LSM6DS3TR_C_GY_ST_POSITIVE = 1,
+    LSM6DS3TR_C_GY_ST_NEGATIVE = 3,
+    LSM6DS3TR_C_GY_ST_ND = 4, /* ERROR CODE */
+} lsm6ds3tr_c_st_g_t;
+int32_t lsm6ds3tr_c_gy_self_test_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_st_g_t val);
+int32_t lsm6ds3tr_c_gy_self_test_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_st_g_t* val);
+
+int32_t lsm6ds3tr_c_filter_settling_mask_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_filter_settling_mask_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_USE_SLOPE = 0,
+    LSM6DS3TR_C_USE_HPF = 1,
+    LSM6DS3TR_C_HP_PATH_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_slope_fds_t;
+int32_t lsm6ds3tr_c_xl_hp_path_internal_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_slope_fds_t val);
+int32_t lsm6ds3tr_c_xl_hp_path_internal_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_slope_fds_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_XL_ANA_BW_1k5Hz = 0,
+    LSM6DS3TR_C_XL_ANA_BW_400Hz = 1,
+    LSM6DS3TR_C_XL_ANA_BW_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_bw0_xl_t;
+int32_t lsm6ds3tr_c_xl_filter_analog_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_bw0_xl_t val);
+int32_t lsm6ds3tr_c_xl_filter_analog_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_bw0_xl_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_XL_LP1_ODR_DIV_2 = 0,
+    LSM6DS3TR_C_XL_LP1_ODR_DIV_4 = 1,
+    LSM6DS3TR_C_XL_LP1_NA = 2, /* ERROR CODE */
+} lsm6ds3tr_c_lpf1_bw_sel_t;
+int32_t lsm6ds3tr_c_xl_lp1_bandwidth_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_lpf1_bw_sel_t val);
+int32_t lsm6ds3tr_c_xl_lp1_bandwidth_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_lpf1_bw_sel_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_50 = 0x00,
+    LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_100 = 0x01,
+    LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_9 = 0x02,
+    LSM6DS3TR_C_XL_LOW_LAT_LP_ODR_DIV_400 = 0x03,
+    LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_50 = 0x10,
+    LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_100 = 0x11,
+    LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_9 = 0x12,
+    LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_400 = 0x13,
+    LSM6DS3TR_C_XL_LP_NA = 0x20, /* ERROR CODE */
+} lsm6ds3tr_c_input_composite_t;
+int32_t lsm6ds3tr_c_xl_lp2_bandwidth_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_input_composite_t val);
+int32_t lsm6ds3tr_c_xl_lp2_bandwidth_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_input_composite_t* val);
+
+int32_t lsm6ds3tr_c_xl_reference_mode_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_xl_reference_mode_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_XL_HP_ODR_DIV_4 = 0x00, /* Slope filter */
+    LSM6DS3TR_C_XL_HP_ODR_DIV_100 = 0x01,
+    LSM6DS3TR_C_XL_HP_ODR_DIV_9 = 0x02,
+    LSM6DS3TR_C_XL_HP_ODR_DIV_400 = 0x03,
+    LSM6DS3TR_C_XL_HP_NA = 0x10, /* ERROR CODE */
+} lsm6ds3tr_c_hpcf_xl_t;
+int32_t lsm6ds3tr_c_xl_hp_bandwidth_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_hpcf_xl_t val);
+int32_t lsm6ds3tr_c_xl_hp_bandwidth_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_hpcf_xl_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_LP2_ONLY = 0x00,
+
+    LSM6DS3TR_C_HP_16mHz_LP2 = 0x80,
+    LSM6DS3TR_C_HP_65mHz_LP2 = 0x90,
+    LSM6DS3TR_C_HP_260mHz_LP2 = 0xA0,
+    LSM6DS3TR_C_HP_1Hz04_LP2 = 0xB0,
+
+    LSM6DS3TR_C_HP_DISABLE_LP1_LIGHT = 0x0A,
+    LSM6DS3TR_C_HP_DISABLE_LP1_NORMAL = 0x09,
+    LSM6DS3TR_C_HP_DISABLE_LP_STRONG = 0x08,
+    LSM6DS3TR_C_HP_DISABLE_LP1_AGGRESSIVE = 0x0B,
+
+    LSM6DS3TR_C_HP_16mHz_LP1_LIGHT = 0x8A,
+    LSM6DS3TR_C_HP_65mHz_LP1_NORMAL = 0x99,
+    LSM6DS3TR_C_HP_260mHz_LP1_STRONG = 0xA8,
+    LSM6DS3TR_C_HP_1Hz04_LP1_AGGRESSIVE = 0xBB,
+
+    LSM6DS3TR_C_HP_GY_BAND_NA = 0xFF, /* ERROR CODE */
+} lsm6ds3tr_c_lpf1_sel_g_t;
+int32_t lsm6ds3tr_c_gy_band_pass_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_lpf1_sel_g_t val);
+int32_t lsm6ds3tr_c_gy_band_pass_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_lpf1_sel_g_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_SPI_4_WIRE = 0,
+    LSM6DS3TR_C_SPI_3_WIRE = 1,
+    LSM6DS3TR_C_SPI_MODE_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_sim_t;
+int32_t lsm6ds3tr_c_spi_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_sim_t val);
+int32_t lsm6ds3tr_c_spi_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_sim_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_I2C_ENABLE = 0,
+    LSM6DS3TR_C_I2C_DISABLE = 1,
+    LSM6DS3TR_C_I2C_MODE_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_i2c_disable_t;
+int32_t lsm6ds3tr_c_i2c_interface_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_i2c_disable_t val);
+int32_t lsm6ds3tr_c_i2c_interface_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_i2c_disable_t* val);
+
+typedef struct {
+    uint8_t int1_drdy_xl : 1;
+    uint8_t int1_drdy_g : 1;
+    uint8_t int1_boot : 1;
+    uint8_t int1_fth : 1;
+    uint8_t int1_fifo_ovr : 1;
+    uint8_t int1_full_flag : 1;
+    uint8_t int1_sign_mot : 1;
+    uint8_t int1_step_detector : 1;
+    uint8_t int1_timer : 1;
+    uint8_t int1_tilt : 1;
+    uint8_t int1_6d : 1;
+    uint8_t int1_double_tap : 1;
+    uint8_t int1_ff : 1;
+    uint8_t int1_wu : 1;
+    uint8_t int1_single_tap : 1;
+    uint8_t int1_inact_state : 1;
+    uint8_t den_drdy_int1 : 1;
+    uint8_t drdy_on_int1 : 1;
+} lsm6ds3tr_c_int1_route_t;
+int32_t lsm6ds3tr_c_pin_int1_route_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_int1_route_t val);
+int32_t lsm6ds3tr_c_pin_int1_route_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_int1_route_t* val);
+
+typedef struct {
+    uint8_t int2_drdy_xl : 1;
+    uint8_t int2_drdy_g : 1;
+    uint8_t int2_drdy_temp : 1;
+    uint8_t int2_fth : 1;
+    uint8_t int2_fifo_ovr : 1;
+    uint8_t int2_full_flag : 1;
+    uint8_t int2_step_count_ov : 1;
+    uint8_t int2_step_delta : 1;
+    uint8_t int2_iron : 1;
+    uint8_t int2_tilt : 1;
+    uint8_t int2_6d : 1;
+    uint8_t int2_double_tap : 1;
+    uint8_t int2_ff : 1;
+    uint8_t int2_wu : 1;
+    uint8_t int2_single_tap : 1;
+    uint8_t int2_inact_state : 1;
+    uint8_t int2_wrist_tilt : 1;
+} lsm6ds3tr_c_int2_route_t;
+int32_t lsm6ds3tr_c_pin_int2_route_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_int2_route_t val);
+int32_t lsm6ds3tr_c_pin_int2_route_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_int2_route_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_PUSH_PULL = 0,
+    LSM6DS3TR_C_OPEN_DRAIN = 1,
+    LSM6DS3TR_C_PIN_MODE_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_pp_od_t;
+int32_t lsm6ds3tr_c_pin_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_pp_od_t val);
+int32_t lsm6ds3tr_c_pin_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_pp_od_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_ACTIVE_HIGH = 0,
+    LSM6DS3TR_C_ACTIVE_LOW = 1,
+    LSM6DS3TR_C_POLARITY_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_h_lactive_t;
+int32_t lsm6ds3tr_c_pin_polarity_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_h_lactive_t val);
+int32_t lsm6ds3tr_c_pin_polarity_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_h_lactive_t* val);
+
+int32_t lsm6ds3tr_c_all_on_int1_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_all_on_int1_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_INT_PULSED = 0,
+    LSM6DS3TR_C_INT_LATCHED = 1,
+    LSM6DS3TR_C_INT_MODE = 2, /* ERROR CODE */
+} lsm6ds3tr_c_lir_t;
+int32_t lsm6ds3tr_c_int_notification_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_lir_t val);
+int32_t lsm6ds3tr_c_int_notification_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_lir_t* val);
+
+int32_t lsm6ds3tr_c_wkup_threshold_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_wkup_threshold_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_wkup_dur_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_wkup_dur_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_gy_sleep_mode_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_gy_sleep_mode_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_PROPERTY_DISABLE = 0,
+    LSM6DS3TR_C_XL_12Hz5_GY_NOT_AFFECTED = 1,
+    LSM6DS3TR_C_XL_12Hz5_GY_SLEEP = 2,
+    LSM6DS3TR_C_XL_12Hz5_GY_PD = 3,
+    LSM6DS3TR_C_ACT_MODE_ND = 4, /* ERROR CODE */
+} lsm6ds3tr_c_inact_en_t;
+int32_t lsm6ds3tr_c_act_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_inact_en_t val);
+int32_t lsm6ds3tr_c_act_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_inact_en_t* val);
+
+int32_t lsm6ds3tr_c_act_sleep_dur_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_act_sleep_dur_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_tap_src_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_tap_src_t* val);
+
+int32_t lsm6ds3tr_c_tap_detection_on_z_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_tap_detection_on_z_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_tap_detection_on_y_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_tap_detection_on_y_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_tap_detection_on_x_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_tap_detection_on_x_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_tap_threshold_x_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_tap_threshold_x_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_tap_shock_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_tap_shock_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_tap_quiet_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_tap_quiet_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_tap_dur_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_tap_dur_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_ONLY_SINGLE = 0,
+    LSM6DS3TR_C_BOTH_SINGLE_DOUBLE = 1,
+    LSM6DS3TR_C_TAP_MODE_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_single_double_tap_t;
+int32_t lsm6ds3tr_c_tap_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_single_double_tap_t val);
+int32_t lsm6ds3tr_c_tap_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_single_double_tap_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_ODR_DIV_2_FEED = 0,
+    LSM6DS3TR_C_LPF2_FEED = 1,
+    LSM6DS3TR_C_6D_FEED_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_low_pass_on_6d_t;
+int32_t lsm6ds3tr_c_6d_feed_data_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_low_pass_on_6d_t val);
+int32_t lsm6ds3tr_c_6d_feed_data_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_low_pass_on_6d_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_DEG_80 = 0,
+    LSM6DS3TR_C_DEG_70 = 1,
+    LSM6DS3TR_C_DEG_60 = 2,
+    LSM6DS3TR_C_DEG_50 = 3,
+    LSM6DS3TR_C_6D_TH_ND = 4, /* ERROR CODE */
+} lsm6ds3tr_c_sixd_ths_t;
+int32_t lsm6ds3tr_c_6d_threshold_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_sixd_ths_t val);
+int32_t lsm6ds3tr_c_6d_threshold_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_sixd_ths_t* val);
+
+int32_t lsm6ds3tr_c_4d_mode_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_4d_mode_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_ff_dur_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_ff_dur_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_FF_TSH_156mg = 0,
+    LSM6DS3TR_C_FF_TSH_219mg = 1,
+    LSM6DS3TR_C_FF_TSH_250mg = 2,
+    LSM6DS3TR_C_FF_TSH_312mg = 3,
+    LSM6DS3TR_C_FF_TSH_344mg = 4,
+    LSM6DS3TR_C_FF_TSH_406mg = 5,
+    LSM6DS3TR_C_FF_TSH_469mg = 6,
+    LSM6DS3TR_C_FF_TSH_500mg = 7,
+    LSM6DS3TR_C_FF_TSH_ND = 8, /* ERROR CODE */
+} lsm6ds3tr_c_ff_ths_t;
+int32_t lsm6ds3tr_c_ff_threshold_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_ff_ths_t val);
+int32_t lsm6ds3tr_c_ff_threshold_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_ff_ths_t* val);
+
+int32_t lsm6ds3tr_c_fifo_watermark_set(stmdev_ctx_t* ctx, uint16_t val);
+int32_t lsm6ds3tr_c_fifo_watermark_get(stmdev_ctx_t* ctx, uint16_t* val);
+
+int32_t lsm6ds3tr_c_fifo_data_level_get(stmdev_ctx_t* ctx, uint16_t* val);
+
+int32_t lsm6ds3tr_c_fifo_wtm_flag_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_fifo_pattern_get(stmdev_ctx_t* ctx, uint16_t* val);
+
+int32_t lsm6ds3tr_c_fifo_temp_batch_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_fifo_temp_batch_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_TRG_XL_GY_DRDY = 0,
+    LSM6DS3TR_C_TRG_STEP_DETECT = 1,
+    LSM6DS3TR_C_TRG_SH_DRDY = 2,
+    LSM6DS3TR_C_TRG_SH_ND = 3, /* ERROR CODE */
+} lsm6ds3tr_c_trigger_fifo_t;
+int32_t lsm6ds3tr_c_fifo_write_trigger_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_trigger_fifo_t val);
+int32_t lsm6ds3tr_c_fifo_write_trigger_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_trigger_fifo_t* val);
+
+int32_t lsm6ds3tr_c_fifo_pedo_and_timestamp_batch_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_fifo_pedo_and_timestamp_batch_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_FIFO_XL_DISABLE = 0,
+    LSM6DS3TR_C_FIFO_XL_NO_DEC = 1,
+    LSM6DS3TR_C_FIFO_XL_DEC_2 = 2,
+    LSM6DS3TR_C_FIFO_XL_DEC_3 = 3,
+    LSM6DS3TR_C_FIFO_XL_DEC_4 = 4,
+    LSM6DS3TR_C_FIFO_XL_DEC_8 = 5,
+    LSM6DS3TR_C_FIFO_XL_DEC_16 = 6,
+    LSM6DS3TR_C_FIFO_XL_DEC_32 = 7,
+    LSM6DS3TR_C_FIFO_XL_DEC_ND = 8, /* ERROR CODE */
+} lsm6ds3tr_c_dec_fifo_xl_t;
+int32_t lsm6ds3tr_c_fifo_xl_batch_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_fifo_xl_t val);
+int32_t lsm6ds3tr_c_fifo_xl_batch_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_fifo_xl_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_FIFO_GY_DISABLE = 0,
+    LSM6DS3TR_C_FIFO_GY_NO_DEC = 1,
+    LSM6DS3TR_C_FIFO_GY_DEC_2 = 2,
+    LSM6DS3TR_C_FIFO_GY_DEC_3 = 3,
+    LSM6DS3TR_C_FIFO_GY_DEC_4 = 4,
+    LSM6DS3TR_C_FIFO_GY_DEC_8 = 5,
+    LSM6DS3TR_C_FIFO_GY_DEC_16 = 6,
+    LSM6DS3TR_C_FIFO_GY_DEC_32 = 7,
+    LSM6DS3TR_C_FIFO_GY_DEC_ND = 8, /* ERROR CODE */
+} lsm6ds3tr_c_dec_fifo_gyro_t;
+int32_t lsm6ds3tr_c_fifo_gy_batch_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_fifo_gyro_t val);
+int32_t lsm6ds3tr_c_fifo_gy_batch_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_fifo_gyro_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_FIFO_DS3_DISABLE = 0,
+    LSM6DS3TR_C_FIFO_DS3_NO_DEC = 1,
+    LSM6DS3TR_C_FIFO_DS3_DEC_2 = 2,
+    LSM6DS3TR_C_FIFO_DS3_DEC_3 = 3,
+    LSM6DS3TR_C_FIFO_DS3_DEC_4 = 4,
+    LSM6DS3TR_C_FIFO_DS3_DEC_8 = 5,
+    LSM6DS3TR_C_FIFO_DS3_DEC_16 = 6,
+    LSM6DS3TR_C_FIFO_DS3_DEC_32 = 7,
+    LSM6DS3TR_C_FIFO_DS3_DEC_ND = 8, /* ERROR CODE */
+} lsm6ds3tr_c_dec_ds3_fifo_t;
+int32_t lsm6ds3tr_c_fifo_dataset_3_batch_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_ds3_fifo_t val);
+int32_t lsm6ds3tr_c_fifo_dataset_3_batch_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_ds3_fifo_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_FIFO_DS4_DISABLE = 0,
+    LSM6DS3TR_C_FIFO_DS4_NO_DEC = 1,
+    LSM6DS3TR_C_FIFO_DS4_DEC_2 = 2,
+    LSM6DS3TR_C_FIFO_DS4_DEC_3 = 3,
+    LSM6DS3TR_C_FIFO_DS4_DEC_4 = 4,
+    LSM6DS3TR_C_FIFO_DS4_DEC_8 = 5,
+    LSM6DS3TR_C_FIFO_DS4_DEC_16 = 6,
+    LSM6DS3TR_C_FIFO_DS4_DEC_32 = 7,
+    LSM6DS3TR_C_FIFO_DS4_DEC_ND = 8, /* ERROR CODE */
+} lsm6ds3tr_c_dec_ds4_fifo_t;
+int32_t lsm6ds3tr_c_fifo_dataset_4_batch_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_ds4_fifo_t val);
+int32_t lsm6ds3tr_c_fifo_dataset_4_batch_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_dec_ds4_fifo_t* val);
+
+int32_t lsm6ds3tr_c_fifo_xl_gy_8bit_format_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_fifo_xl_gy_8bit_format_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_fifo_stop_on_wtm_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_fifo_stop_on_wtm_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_BYPASS_MODE = 0,
+    LSM6DS3TR_C_FIFO_MODE = 1,
+    LSM6DS3TR_C_STREAM_TO_FIFO_MODE = 3,
+    LSM6DS3TR_C_BYPASS_TO_STREAM_MODE = 4,
+    LSM6DS3TR_C_STREAM_MODE = 6,
+    LSM6DS3TR_C_FIFO_MODE_ND = 8, /* ERROR CODE */
+} lsm6ds3tr_c_fifo_mode_t;
+int32_t lsm6ds3tr_c_fifo_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_fifo_mode_t val);
+int32_t lsm6ds3tr_c_fifo_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_fifo_mode_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_FIFO_DISABLE = 0,
+    LSM6DS3TR_C_FIFO_12Hz5 = 1,
+    LSM6DS3TR_C_FIFO_26Hz = 2,
+    LSM6DS3TR_C_FIFO_52Hz = 3,
+    LSM6DS3TR_C_FIFO_104Hz = 4,
+    LSM6DS3TR_C_FIFO_208Hz = 5,
+    LSM6DS3TR_C_FIFO_416Hz = 6,
+    LSM6DS3TR_C_FIFO_833Hz = 7,
+    LSM6DS3TR_C_FIFO_1k66Hz = 8,
+    LSM6DS3TR_C_FIFO_3k33Hz = 9,
+    LSM6DS3TR_C_FIFO_6k66Hz = 10,
+    LSM6DS3TR_C_FIFO_RATE_ND = 11, /* ERROR CODE */
+} lsm6ds3tr_c_odr_fifo_t;
+int32_t lsm6ds3tr_c_fifo_data_rate_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_fifo_t val);
+int32_t lsm6ds3tr_c_fifo_data_rate_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_odr_fifo_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_DEN_ACT_LOW = 0,
+    LSM6DS3TR_C_DEN_ACT_HIGH = 1,
+    LSM6DS3TR_C_DEN_POL_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_den_lh_t;
+int32_t lsm6ds3tr_c_den_polarity_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_lh_t val);
+int32_t lsm6ds3tr_c_den_polarity_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_lh_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_DEN_DISABLE = 0,
+    LSM6DS3TR_C_LEVEL_FIFO = 6,
+    LSM6DS3TR_C_LEVEL_LETCHED = 3,
+    LSM6DS3TR_C_LEVEL_TRIGGER = 2,
+    LSM6DS3TR_C_EDGE_TRIGGER = 4,
+    LSM6DS3TR_C_DEN_MODE_ND = 5, /* ERROR CODE */
+} lsm6ds3tr_c_den_mode_t;
+int32_t lsm6ds3tr_c_den_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_mode_t val);
+int32_t lsm6ds3tr_c_den_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_mode_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_STAMP_IN_GY_DATA = 0,
+    LSM6DS3TR_C_STAMP_IN_XL_DATA = 1,
+    LSM6DS3TR_C_STAMP_IN_GY_XL_DATA = 2,
+    LSM6DS3TR_C_DEN_STAMP_ND = 3, /* ERROR CODE */
+} lsm6ds3tr_c_den_xl_en_t;
+int32_t lsm6ds3tr_c_den_enable_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_xl_en_t val);
+int32_t lsm6ds3tr_c_den_enable_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_den_xl_en_t* val);
+
+int32_t lsm6ds3tr_c_den_mark_axis_z_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_den_mark_axis_z_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_den_mark_axis_y_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_den_mark_axis_y_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_den_mark_axis_x_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_den_mark_axis_x_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_pedo_step_reset_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_pedo_step_reset_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_pedo_sens_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_pedo_sens_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_pedo_threshold_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_pedo_threshold_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_PEDO_AT_2g = 0,
+    LSM6DS3TR_C_PEDO_AT_4g = 1,
+    LSM6DS3TR_C_PEDO_FS_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_pedo_fs_t;
+int32_t lsm6ds3tr_c_pedo_full_scale_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_pedo_fs_t val);
+int32_t lsm6ds3tr_c_pedo_full_scale_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_pedo_fs_t* val);
+
+int32_t lsm6ds3tr_c_pedo_debounce_steps_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_pedo_debounce_steps_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_pedo_timeout_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_pedo_timeout_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_pedo_steps_period_set(stmdev_ctx_t* ctx, uint8_t* buff);
+int32_t lsm6ds3tr_c_pedo_steps_period_get(stmdev_ctx_t* ctx, uint8_t* buff);
+
+int32_t lsm6ds3tr_c_motion_sens_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_motion_sens_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_motion_threshold_set(stmdev_ctx_t* ctx, uint8_t* buff);
+int32_t lsm6ds3tr_c_motion_threshold_get(stmdev_ctx_t* ctx, uint8_t* buff);
+
+int32_t lsm6ds3tr_c_tilt_sens_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_tilt_sens_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_wrist_tilt_sens_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_wrist_tilt_sens_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_tilt_latency_set(stmdev_ctx_t* ctx, uint8_t* buff);
+int32_t lsm6ds3tr_c_tilt_latency_get(stmdev_ctx_t* ctx, uint8_t* buff);
+
+int32_t lsm6ds3tr_c_tilt_threshold_set(stmdev_ctx_t* ctx, uint8_t* buff);
+int32_t lsm6ds3tr_c_tilt_threshold_get(stmdev_ctx_t* ctx, uint8_t* buff);
+
+int32_t lsm6ds3tr_c_tilt_src_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_a_wrist_tilt_mask_t* val);
+int32_t lsm6ds3tr_c_tilt_src_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_a_wrist_tilt_mask_t* val);
+
+int32_t lsm6ds3tr_c_mag_soft_iron_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_mag_soft_iron_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_mag_hard_iron_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_mag_hard_iron_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_mag_soft_iron_mat_set(stmdev_ctx_t* ctx, uint8_t* buff);
+int32_t lsm6ds3tr_c_mag_soft_iron_mat_get(stmdev_ctx_t* ctx, uint8_t* buff);
+
+int32_t lsm6ds3tr_c_mag_offset_set(stmdev_ctx_t* ctx, int16_t* val);
+int32_t lsm6ds3tr_c_mag_offset_get(stmdev_ctx_t* ctx, int16_t* val);
+
+int32_t lsm6ds3tr_c_func_en_set(stmdev_ctx_t* ctx, uint8_t val);
+
+int32_t lsm6ds3tr_c_sh_sync_sens_frame_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_sh_sync_sens_frame_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_RES_RATIO_2_11 = 0,
+    LSM6DS3TR_C_RES_RATIO_2_12 = 1,
+    LSM6DS3TR_C_RES_RATIO_2_13 = 2,
+    LSM6DS3TR_C_RES_RATIO_2_14 = 3,
+    LSM6DS3TR_C_RES_RATIO_ND = 4, /* ERROR CODE */
+} lsm6ds3tr_c_rr_t;
+int32_t lsm6ds3tr_c_sh_sync_sens_ratio_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_rr_t val);
+int32_t lsm6ds3tr_c_sh_sync_sens_ratio_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_rr_t* val);
+
+int32_t lsm6ds3tr_c_sh_master_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_sh_master_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_sh_pass_through_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_sh_pass_through_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_EXT_PULL_UP = 0,
+    LSM6DS3TR_C_INTERNAL_PULL_UP = 1,
+    LSM6DS3TR_C_SH_PIN_MODE = 2, /* ERROR CODE */
+} lsm6ds3tr_c_pull_up_en_t;
+int32_t lsm6ds3tr_c_sh_pin_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_pull_up_en_t val);
+int32_t lsm6ds3tr_c_sh_pin_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_pull_up_en_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_XL_GY_DRDY = 0,
+    LSM6DS3TR_C_EXT_ON_INT2_PIN = 1,
+    LSM6DS3TR_C_SH_SYNCRO_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_start_config_t;
+int32_t lsm6ds3tr_c_sh_syncro_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_start_config_t val);
+int32_t lsm6ds3tr_c_sh_syncro_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_start_config_t* val);
+
+int32_t lsm6ds3tr_c_sh_drdy_on_int1_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_sh_drdy_on_int1_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef struct {
+    lsm6ds3tr_c_sensorhub1_reg_t sh_byte_1;
+    lsm6ds3tr_c_sensorhub2_reg_t sh_byte_2;
+    lsm6ds3tr_c_sensorhub3_reg_t sh_byte_3;
+    lsm6ds3tr_c_sensorhub4_reg_t sh_byte_4;
+    lsm6ds3tr_c_sensorhub5_reg_t sh_byte_5;
+    lsm6ds3tr_c_sensorhub6_reg_t sh_byte_6;
+    lsm6ds3tr_c_sensorhub7_reg_t sh_byte_7;
+    lsm6ds3tr_c_sensorhub8_reg_t sh_byte_8;
+    lsm6ds3tr_c_sensorhub9_reg_t sh_byte_9;
+    lsm6ds3tr_c_sensorhub10_reg_t sh_byte_10;
+    lsm6ds3tr_c_sensorhub11_reg_t sh_byte_11;
+    lsm6ds3tr_c_sensorhub12_reg_t sh_byte_12;
+    lsm6ds3tr_c_sensorhub13_reg_t sh_byte_13;
+    lsm6ds3tr_c_sensorhub14_reg_t sh_byte_14;
+    lsm6ds3tr_c_sensorhub15_reg_t sh_byte_15;
+    lsm6ds3tr_c_sensorhub16_reg_t sh_byte_16;
+    lsm6ds3tr_c_sensorhub17_reg_t sh_byte_17;
+    lsm6ds3tr_c_sensorhub18_reg_t sh_byte_18;
+} lsm6ds3tr_c_emb_sh_read_t;
+int32_t lsm6ds3tr_c_sh_read_data_raw_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_emb_sh_read_t* val);
+
+int32_t lsm6ds3tr_c_sh_cmd_sens_sync_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_sh_cmd_sens_sync_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+int32_t lsm6ds3tr_c_sh_spi_sync_error_set(stmdev_ctx_t* ctx, uint8_t val);
+int32_t lsm6ds3tr_c_sh_spi_sync_error_get(stmdev_ctx_t* ctx, uint8_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_SLV_0 = 0,
+    LSM6DS3TR_C_SLV_0_1 = 1,
+    LSM6DS3TR_C_SLV_0_1_2 = 2,
+    LSM6DS3TR_C_SLV_0_1_2_3 = 3,
+    LSM6DS3TR_C_SLV_EN_ND = 4, /* ERROR CODE */
+} lsm6ds3tr_c_aux_sens_on_t;
+int32_t lsm6ds3tr_c_sh_num_of_dev_connected_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_aux_sens_on_t val);
+int32_t lsm6ds3tr_c_sh_num_of_dev_connected_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_aux_sens_on_t* val);
+
+typedef struct {
+    uint8_t slv0_add;
+    uint8_t slv0_subadd;
+    uint8_t slv0_data;
+} lsm6ds3tr_c_sh_cfg_write_t;
+int32_t lsm6ds3tr_c_sh_cfg_write(stmdev_ctx_t* ctx, lsm6ds3tr_c_sh_cfg_write_t* val);
+
+typedef struct {
+    uint8_t slv_add;
+    uint8_t slv_subadd;
+    uint8_t slv_len;
+} lsm6ds3tr_c_sh_cfg_read_t;
+int32_t lsm6ds3tr_c_sh_slv0_cfg_read(stmdev_ctx_t* ctx, lsm6ds3tr_c_sh_cfg_read_t* val);
+int32_t lsm6ds3tr_c_sh_slv1_cfg_read(stmdev_ctx_t* ctx, lsm6ds3tr_c_sh_cfg_read_t* val);
+int32_t lsm6ds3tr_c_sh_slv2_cfg_read(stmdev_ctx_t* ctx, lsm6ds3tr_c_sh_cfg_read_t* val);
+int32_t lsm6ds3tr_c_sh_slv3_cfg_read(stmdev_ctx_t* ctx, lsm6ds3tr_c_sh_cfg_read_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_SL0_NO_DEC = 0,
+    LSM6DS3TR_C_SL0_DEC_2 = 1,
+    LSM6DS3TR_C_SL0_DEC_4 = 2,
+    LSM6DS3TR_C_SL0_DEC_8 = 3,
+    LSM6DS3TR_C_SL0_DEC_ND = 4, /* ERROR CODE */
+} lsm6ds3tr_c_slave0_rate_t;
+int32_t lsm6ds3tr_c_sh_slave_0_dec_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave0_rate_t val);
+int32_t lsm6ds3tr_c_sh_slave_0_dec_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave0_rate_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_EACH_SH_CYCLE = 0,
+    LSM6DS3TR_C_ONLY_FIRST_CYCLE = 1,
+    LSM6DS3TR_C_SH_WR_MODE_ND = 2, /* ERROR CODE */
+} lsm6ds3tr_c_write_once_t;
+int32_t lsm6ds3tr_c_sh_write_mode_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_write_once_t val);
+int32_t lsm6ds3tr_c_sh_write_mode_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_write_once_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_SL1_NO_DEC = 0,
+    LSM6DS3TR_C_SL1_DEC_2 = 1,
+    LSM6DS3TR_C_SL1_DEC_4 = 2,
+    LSM6DS3TR_C_SL1_DEC_8 = 3,
+    LSM6DS3TR_C_SL1_DEC_ND = 4, /* ERROR CODE */
+} lsm6ds3tr_c_slave1_rate_t;
+int32_t lsm6ds3tr_c_sh_slave_1_dec_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave1_rate_t val);
+int32_t lsm6ds3tr_c_sh_slave_1_dec_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave1_rate_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_SL2_NO_DEC = 0,
+    LSM6DS3TR_C_SL2_DEC_2 = 1,
+    LSM6DS3TR_C_SL2_DEC_4 = 2,
+    LSM6DS3TR_C_SL2_DEC_8 = 3,
+    LSM6DS3TR_C_SL2_DEC_ND = 4, /* ERROR CODE */
+} lsm6ds3tr_c_slave2_rate_t;
+int32_t lsm6ds3tr_c_sh_slave_2_dec_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave2_rate_t val);
+int32_t lsm6ds3tr_c_sh_slave_2_dec_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave2_rate_t* val);
+
+typedef enum {
+    LSM6DS3TR_C_SL3_NO_DEC = 0,
+    LSM6DS3TR_C_SL3_DEC_2 = 1,
+    LSM6DS3TR_C_SL3_DEC_4 = 2,
+    LSM6DS3TR_C_SL3_DEC_8 = 3,
+    LSM6DS3TR_C_SL3_DEC_ND = 4, /* ERROR CODE */
+} lsm6ds3tr_c_slave3_rate_t;
+int32_t lsm6ds3tr_c_sh_slave_3_dec_set(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave3_rate_t val);
+int32_t lsm6ds3tr_c_sh_slave_3_dec_get(stmdev_ctx_t* ctx, lsm6ds3tr_c_slave3_rate_t* val);
+
+/**
+  * @}
+  *
+  */
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* LSM6DS3TR_C_DRIVER_H */
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/

+ 9 - 3
tracking/sensors/lowpass_filter.h

@@ -51,13 +51,19 @@ public:
 
     // Returns the filtered value. A vector with zeros is returned if no samples
     // have been added.
-    Vector3 GetFilteredData() const { return filtered_data_; }
+    Vector3 GetFilteredData() const {
+        return filtered_data_;
+    }
 
     // Returns the most recent update timestamp in ns.
-    uint64_t GetMostRecentTimestampNs() const { return timestamp_most_recent_update_ns_; }
+    uint64_t GetMostRecentTimestampNs() const {
+        return timestamp_most_recent_update_ns_;
+    }
 
     // Returns true when the filter is initialized.
-    bool IsInitialized() const { return initialized_; }
+    bool IsInitialized() const {
+        return initialized_;
+    }
 
     // Resets filter state.
     void Reset();

+ 24 - 24
tracking/sensors/pose_prediction.h

@@ -24,30 +24,30 @@
 namespace cardboard {
 namespace pose_prediction {
 
-    // Returns a rotation matrix based on the integration of the gyroscope_value
-    // over the timestep_s in seconds.
-    // TODO(pfg): Document the space better here.
-    //
-    // @param gyroscope_value gyroscope sensor values.
-    // @param timestep_s integration period in seconds.
-    // @return Integration of the gyroscope value the rotation is from Start to
-    //         Sensor Space.
-    Rotation GetRotationFromGyroscope(const Vector3& gyroscope_value, double timestep_s);
-
-    // Gets a predicted pose for a given time in the future (e.g. rendering time)
-    // based on a linear prediction model. This uses the system current state
-    // (position, velocity, etc) from the past to extrapolate a position in the
-    // future.
-    //
-    // @param requested_pose_timestamp time at which you want the pose.
-    // @param current_state current state that stores the pose and linear model at a
-    //        given time prior to requested_pose_timestamp_ns.
-    // @return pose from Start to Sensor Space.
-    Rotation PredictPose(int64_t requested_pose_timestamp, const PoseState& current_state);
-
-    // Equivalent to PredictPose, but for use with poses relative to Start Space
-    // rather than sensor space.
-    Rotation PredictPoseInv(int64_t requested_pose_timestamp, const PoseState& current_state);
+// Returns a rotation matrix based on the integration of the gyroscope_value
+// over the timestep_s in seconds.
+// TODO(pfg): Document the space better here.
+//
+// @param gyroscope_value gyroscope sensor values.
+// @param timestep_s integration period in seconds.
+// @return Integration of the gyroscope value the rotation is from Start to
+//         Sensor Space.
+Rotation GetRotationFromGyroscope(const Vector3& gyroscope_value, double timestep_s);
+
+// Gets a predicted pose for a given time in the future (e.g. rendering time)
+// based on a linear prediction model. This uses the system current state
+// (position, velocity, etc) from the past to extrapolate a position in the
+// future.
+//
+// @param requested_pose_timestamp time at which you want the pose.
+// @param current_state current state that stores the pose and linear model at a
+//        given time prior to requested_pose_timestamp_ns.
+// @return pose from Start to Sensor Space.
+Rotation PredictPose(int64_t requested_pose_timestamp, const PoseState& current_state);
+
+// Equivalent to PredictPose, but for use with poses relative to Start Space
+// rather than sensor space.
+Rotation PredictPoseInv(int64_t requested_pose_timestamp, const PoseState& current_state);
 
 } // namespace pose_prediction
 } // namespace cardboard

+ 6 - 5
tracking/sensors/sensor_fusion_ekf.h

@@ -76,14 +76,15 @@ public:
     bool IsBiasEstimationEnabled() const;
 
     // Returns the current gyroscope bias estimate from GyroscopeBiasEstimator.
-    Vector3 GetGyroscopeBias() const
-    {
-        return { gyroscope_bias_estimate_[0], gyroscope_bias_estimate_[1],
-            gyroscope_bias_estimate_[2] };
+    Vector3 GetGyroscopeBias() const {
+        return {
+            gyroscope_bias_estimate_[0], gyroscope_bias_estimate_[1], gyroscope_bias_estimate_[2]};
     }
 
     // Returns true after receiving the first accelerometer measurement.
-    bool IsFullyInitialized() const { return is_aligned_with_gravity_; }
+    bool IsFullyInitialized() const {
+        return is_aligned_with_gravity_;
+    }
 
 private:
     // Estimates the average timestep between gyroscope event.

+ 54 - 20
tracking/util/matrix_3x3.h

@@ -32,8 +32,16 @@ public:
     Matrix3x3();
 
     // Dimension-specific constructors that are passed individual element values.
-    Matrix3x3(double m00, double m01, double m02, double m10, double m11, double m12, double m20,
-        double m21, double m22);
+    Matrix3x3(
+        double m00,
+        double m01,
+        double m02,
+        double m10,
+        double m11,
+        double m12,
+        double m20,
+        double m21,
+        double m22);
 
     // Constructor that reads elements from a linear array of the correct size.
     explicit Matrix3x3(const double array[3 * 3]);
@@ -45,46 +53,72 @@ public:
     static Matrix3x3 Identity();
 
     // Mutable element accessors.
-    double& operator()(int row, int col) { return elem_[row][col]; }
-    std::array<double, 3>& operator[](int row) { return elem_[row]; }
+    double& operator()(int row, int col) {
+        return elem_[row][col];
+    }
+    std::array<double, 3>& operator[](int row) {
+        return elem_[row];
+    }
 
     // Read-only element accessors.
-    const double& operator()(int row, int col) const { return elem_[row][col]; }
-    const std::array<double, 3>& operator[](int row) const { return elem_[row]; }
+    const double& operator()(int row, int col) const {
+        return elem_[row][col];
+    }
+    const std::array<double, 3>& operator[](int row) const {
+        return elem_[row];
+    }
 
     // Return a pointer to the data for interfacing with libraries.
-    double* Data() { return &elem_[0][0]; }
-    const double* Data() const { return &elem_[0][0]; }
+    double* Data() {
+        return &elem_[0][0];
+    }
+    const double* Data() const {
+        return &elem_[0][0];
+    }
 
     // Self-modifying multiplication operators.
-    void operator*=(double s) { MultiplyScalar(s); }
-    void operator*=(const Matrix3x3& m) { *this = Product(*this, m); }
+    void operator*=(double s) {
+        MultiplyScalar(s);
+    }
+    void operator*=(const Matrix3x3& m) {
+        *this = Product(*this, m);
+    }
 
     // Unary operators.
-    Matrix3x3 operator-() const { return Negation(); }
+    Matrix3x3 operator-() const {
+        return Negation();
+    }
 
     // Binary scale operators.
-    friend Matrix3x3 operator*(const Matrix3x3& m, double s) { return Scale(m, s); }
-    friend Matrix3x3 operator*(double s, const Matrix3x3& m) { return Scale(m, s); }
+    friend Matrix3x3 operator*(const Matrix3x3& m, double s) {
+        return Scale(m, s);
+    }
+    friend Matrix3x3 operator*(double s, const Matrix3x3& m) {
+        return Scale(m, s);
+    }
 
     // Binary matrix addition.
-    friend Matrix3x3 operator+(const Matrix3x3& lhs, const Matrix3x3& rhs)
-    {
+    friend Matrix3x3 operator+(const Matrix3x3& lhs, const Matrix3x3& rhs) {
         return Addition(lhs, rhs);
     }
 
     // Binary matrix subtraction.
-    friend Matrix3x3 operator-(const Matrix3x3& lhs, const Matrix3x3& rhs)
-    {
+    friend Matrix3x3 operator-(const Matrix3x3& lhs, const Matrix3x3& rhs) {
         return Subtraction(lhs, rhs);
     }
 
     // Binary multiplication operator.
-    friend Matrix3x3 operator*(const Matrix3x3& m0, const Matrix3x3& m1) { return Product(m0, m1); }
+    friend Matrix3x3 operator*(const Matrix3x3& m0, const Matrix3x3& m1) {
+        return Product(m0, m1);
+    }
 
     // Exact equality and inequality comparisons.
-    friend bool operator==(const Matrix3x3& m0, const Matrix3x3& m1) { return AreEqual(m0, m1); }
-    friend bool operator!=(const Matrix3x3& m0, const Matrix3x3& m1) { return !AreEqual(m0, m1); }
+    friend bool operator==(const Matrix3x3& m0, const Matrix3x3& m1) {
+        return AreEqual(m0, m1);
+    }
+    friend bool operator!=(const Matrix3x3& m0, const Matrix3x3& m1) {
+        return !AreEqual(m0, m1);
+    }
 
 private:
     // These private functions implement most of the operators.

+ 23 - 23
tracking/util/rotation.h

@@ -31,16 +31,24 @@ public:
     typedef Vector<4> QuaternionType;
 
     // The default constructor creates an identity Rotation, which has no effect.
-    Rotation() { quat_.Set(0, 0, 0, 1); }
+    Rotation() {
+        quat_.Set(0, 0, 0, 1);
+    }
 
     // Returns an identity Rotation, which has no effect.
-    static Rotation Identity() { return Rotation(); }
+    static Rotation Identity() {
+        return Rotation();
+    }
 
     // Sets the Rotation from a quaternion (4D vector), which is first normalized.
-    void SetQuaternion(const QuaternionType& quaternion) { quat_ = Normalized(quaternion); }
+    void SetQuaternion(const QuaternionType& quaternion) {
+        quat_ = Normalized(quaternion);
+    }
 
     // Returns the Rotation as a normalized quaternion (4D vector).
-    const QuaternionType& GetQuaternion() const { return quat_; }
+    const QuaternionType& GetQuaternion() const {
+        return quat_;
+    }
 
     // Sets the Rotation to rotate by the given angle around the given axis,
     // following the right-hand rule. The axis does not need to be unit
@@ -54,8 +62,7 @@ public:
 
     // Convenience function that constructs and returns a Rotation given an axis
     // and angle.
-    static Rotation FromAxisAndAngle(const VectorType& axis, double angle)
-    {
+    static Rotation FromAxisAndAngle(const VectorType& axis, double angle) {
         Rotation r;
         r.SetAxisAndAngle(axis, angle);
         return r;
@@ -63,8 +70,7 @@ public:
 
     // Convenience function that constructs and returns a Rotation given a
     // quaternion.
-    static Rotation FromQuaternion(const QuaternionType& quat)
-    {
+    static Rotation FromQuaternion(const QuaternionType& quat) {
         Rotation r;
         r.SetQuaternion(quat);
         return r;
@@ -77,8 +83,7 @@ public:
     // Convenience function that constructs and returns a Rotation given Euler
     // angles that are applied in the order of rotate-Z by roll, rotate-X by
     // pitch, rotate-Y by yaw (same as GetRollPitchYaw).
-    static Rotation FromRollPitchYaw(double roll, double pitch, double yaw)
-    {
+    static Rotation FromRollPitchYaw(double roll, double pitch, double yaw) {
         VectorType x(1, 0, 0), y(0, 1, 0), z(0, 0, 1);
         return FromAxisAndAngle(z, roll) * (FromAxisAndAngle(x, pitch) * FromAxisAndAngle(y, yaw));
     }
@@ -86,8 +91,7 @@ public:
     // Convenience function that constructs and returns a Rotation given Euler
     // angles that are applied in the order of rotate-Y by yaw, rotate-X by
     // pitch, rotate-Z by roll (same as GetYawPitchRoll).
-    static Rotation FromYawPitchRoll(double yaw, double pitch, double roll)
-    {
+    static Rotation FromYawPitchRoll(double yaw, double pitch, double roll) {
         VectorType x(1, 0, 0), y(0, 1, 0), z(0, 0, 1);
         return FromAxisAndAngle(y, yaw) * (FromAxisAndAngle(x, pitch) * FromAxisAndAngle(z, roll));
     }
@@ -98,19 +102,18 @@ public:
     static Rotation RotateInto(const VectorType& from, const VectorType& to);
 
     // The negation operator returns the inverse rotation.
-    friend Rotation operator-(const Rotation& r)
-    {
+    friend Rotation operator-(const Rotation& r) {
         // Because we store normalized quaternions, the inverse is found by
         // negating the vector part.
         return Rotation(-r.quat_[0], -r.quat_[1], -r.quat_[2], r.quat_[3]);
     }
 
     // Appends a rotation to this one.
-    Rotation& operator*=(const Rotation& r)
-    {
+    Rotation& operator*=(const Rotation& r) {
         const QuaternionType& qr = r.quat_;
         QuaternionType& qt = quat_;
-        SetQuaternion(QuaternionType(qr[3] * qt[0] + qr[0] * qt[3] + qr[2] * qt[1] - qr[1] * qt[2],
+        SetQuaternion(QuaternionType(
+            qr[3] * qt[0] + qr[0] * qt[3] + qr[2] * qt[1] - qr[1] * qt[2],
             qr[3] * qt[1] + qr[1] * qt[3] + qr[0] * qt[2] - qr[2] * qt[0],
             qr[3] * qt[2] + qr[2] * qt[3] + qr[1] * qt[0] - qr[0] * qt[1],
             qr[3] * qt[3] - qr[0] * qt[0] - qr[1] * qt[1] - qr[2] * qt[2]));
@@ -118,8 +121,7 @@ public:
     }
 
     // Binary multiplication operator - returns a composite Rotation.
-    friend const Rotation operator*(const Rotation& r0, const Rotation& r1)
-    {
+    friend const Rotation operator*(const Rotation& r0, const Rotation& r1) {
         Rotation r = r0;
         r *= r1;
         return r;
@@ -131,14 +133,12 @@ public:
 private:
     // Private constructor that builds a Rotation from quaternion components.
     Rotation(double q0, double q1, double q2, double q3)
-        : quat_(q0, q1, q2, q3)
-    {
+        : quat_(q0, q1, q2, q3) {
     }
 
     // Applies a Rotation to a Vector to rotate the Vector. Method borrowed from:
     // http://blog.molecular-matters.com/2013/05/24/a-faster-quaternion-vector-multiplication/
-    VectorType ApplyToVector(const VectorType& v) const
-    {
+    VectorType ApplyToVector(const VectorType& v) const {
         VectorType im(quat_[0], quat_[1], quat_[2]);
         VectorType temp = 2.0 * Cross(im, v);
         return v + quat_[3] * temp + Cross(im, temp);

+ 80 - 58
tracking/util/vector.h

@@ -21,7 +21,8 @@
 namespace cardboard {
 
 // Geometric N-dimensional Vector class.
-template <int Dimension> class Vector {
+template <int Dimension>
+class Vector {
 public:
     // The default constructor zero-initializes all elements.
     Vector();
@@ -36,33 +37,59 @@ public:
 
     void Set(double e0, double e1, double e2); // Only when Dimension == 3.
     void Set(double e0, double e1, double e2,
-        double e3); // Only when Dimension == 4.
+             double e3); // Only when Dimension == 4.
 
     // Mutable element accessor.
-    double& operator[](int index) { return elem_[index]; }
+    double& operator[](int index) {
+        return elem_[index];
+    }
 
     // Element accessor.
-    double operator[](int index) const { return elem_[index]; }
+    double operator[](int index) const {
+        return elem_[index];
+    }
 
     // Returns a Vector containing all zeroes.
     static Vector Zero();
 
     // Self-modifying operators.
-    void operator+=(const Vector& v) { Add(v); }
-    void operator-=(const Vector& v) { Subtract(v); }
-    void operator*=(double s) { Multiply(s); }
-    void operator/=(double s) { Divide(s); }
+    void operator+=(const Vector& v) {
+        Add(v);
+    }
+    void operator-=(const Vector& v) {
+        Subtract(v);
+    }
+    void operator*=(double s) {
+        Multiply(s);
+    }
+    void operator/=(double s) {
+        Divide(s);
+    }
 
     // Unary negation operator.
-    Vector operator-() const { return Negation(); }
+    Vector operator-() const {
+        return Negation();
+    }
 
     // Binary operators.
-    friend Vector operator+(const Vector& v0, const Vector& v1) { return Sum(v0, v1); }
-    friend Vector operator-(const Vector& v0, const Vector& v1) { return Difference(v0, v1); }
-    friend Vector operator*(const Vector& v, double s) { return Scale(v, s); }
-    friend Vector operator*(double s, const Vector& v) { return Scale(v, s); }
-    friend Vector operator*(const Vector& v, const Vector& s) { return Product(v, s); }
-    friend Vector operator/(const Vector& v, double s) { return Divide(v, s); }
+    friend Vector operator+(const Vector& v0, const Vector& v1) {
+        return Sum(v0, v1);
+    }
+    friend Vector operator-(const Vector& v0, const Vector& v1) {
+        return Difference(v0, v1);
+    }
+    friend Vector operator*(const Vector& v, double s) {
+        return Scale(v, s);
+    }
+    friend Vector operator*(double s, const Vector& v) {
+        return Scale(v, s);
+    }
+    friend Vector operator*(const Vector& v, const Vector& s) {
+        return Product(v, s);
+    }
+    friend Vector operator/(const Vector& v, double s) {
+        return Divide(v, s);
+    }
 
     // Self-modifying addition.
     void Add(const Vector& v);
@@ -92,130 +119,125 @@ private:
 };
 //------------------------------------------------------------------------------
 
-template <int Dimension> Vector<Dimension>::Vector()
-{
-    for (int i = 0; i < Dimension; i++) {
+template <int Dimension>
+Vector<Dimension>::Vector() {
+    for(int i = 0; i < Dimension; i++) {
         elem_[i] = 0;
     }
 }
 
 template <int Dimension>
 constexpr Vector<Dimension>::Vector(double e0, double e1, double e2)
-    : elem_ { e0, e1, e2 }
-{
+    : elem_{e0, e1, e2} {
 }
 
 template <int Dimension>
 constexpr Vector<Dimension>::Vector(double e0, double e1, double e2, double e3)
-    : elem_ { e0, e1, e2, e3 }
-{
+    : elem_{e0, e1, e2, e3} {
 }
 /*
 template <>
 constexpr Vector<4>::Vector(const Vector<3>& v, double s)
     : elem_{v[0], v[1], v[2], s} {}
 */
-template <int Dimension> void Vector<Dimension>::Set(double e0, double e1, double e2)
-{
+template <int Dimension>
+void Vector<Dimension>::Set(double e0, double e1, double e2) {
     elem_[0] = e0;
     elem_[1] = e1;
     elem_[2] = e2;
 }
 
-template <int Dimension> void Vector<Dimension>::Set(double e0, double e1, double e2, double e3)
-{
+template <int Dimension>
+void Vector<Dimension>::Set(double e0, double e1, double e2, double e3) {
     elem_[0] = e0;
     elem_[1] = e1;
     elem_[2] = e2;
     elem_[3] = e3;
 }
 
-template <int Dimension> Vector<Dimension> Vector<Dimension>::Zero()
-{
+template <int Dimension>
+Vector<Dimension> Vector<Dimension>::Zero() {
     Vector<Dimension> v;
     return v;
 }
 
-template <int Dimension> void Vector<Dimension>::Add(const Vector& v)
-{
-    for (int i = 0; i < Dimension; i++) {
+template <int Dimension>
+void Vector<Dimension>::Add(const Vector& v) {
+    for(int i = 0; i < Dimension; i++) {
         elem_[i] += v[i];
     }
 }
 
-template <int Dimension> void Vector<Dimension>::Subtract(const Vector& v)
-{
-    for (int i = 0; i < Dimension; i++) {
+template <int Dimension>
+void Vector<Dimension>::Subtract(const Vector& v) {
+    for(int i = 0; i < Dimension; i++) {
         elem_[i] -= v[i];
     }
 }
 
-template <int Dimension> void Vector<Dimension>::Multiply(double s)
-{
-    for (int i = 0; i < Dimension; i++) {
+template <int Dimension>
+void Vector<Dimension>::Multiply(double s) {
+    for(int i = 0; i < Dimension; i++) {
         elem_[i] *= s;
     }
 }
 
-template <int Dimension> void Vector<Dimension>::Divide(double s)
-{
-    for (int i = 0; i < Dimension; i++) {
+template <int Dimension>
+void Vector<Dimension>::Divide(double s) {
+    for(int i = 0; i < Dimension; i++) {
         elem_[i] /= s;
     }
 }
 
-template <int Dimension> Vector<Dimension> Vector<Dimension>::Negation() const
-{
+template <int Dimension>
+Vector<Dimension> Vector<Dimension>::Negation() const {
     Vector<Dimension> ret;
-    for (int i = 0; i < Dimension; i++) {
+    for(int i = 0; i < Dimension; i++) {
         ret.elem_[i] = -elem_[i];
     }
     return ret;
 }
 
 template <int Dimension>
-Vector<Dimension> Vector<Dimension>::Product(const Vector& v0, const Vector& v1)
-{
+Vector<Dimension> Vector<Dimension>::Product(const Vector& v0, const Vector& v1) {
     Vector<Dimension> ret;
-    for (int i = 0; i < Dimension; i++) {
+    for(int i = 0; i < Dimension; i++) {
         ret.elem_[i] = v0[i] * v1[i];
     }
     return ret;
 }
 
 template <int Dimension>
-Vector<Dimension> Vector<Dimension>::Sum(const Vector& v0, const Vector& v1)
-{
+Vector<Dimension> Vector<Dimension>::Sum(const Vector& v0, const Vector& v1) {
     Vector<Dimension> ret;
-    for (int i = 0; i < Dimension; i++) {
+    for(int i = 0; i < Dimension; i++) {
         ret.elem_[i] = v0[i] + v1[i];
     }
     return ret;
 }
 
 template <int Dimension>
-Vector<Dimension> Vector<Dimension>::Difference(const Vector& v0, const Vector& v1)
-{
+Vector<Dimension> Vector<Dimension>::Difference(const Vector& v0, const Vector& v1) {
     Vector<Dimension> ret;
-    for (int i = 0; i < Dimension; i++) {
+    for(int i = 0; i < Dimension; i++) {
         ret.elem_[i] = v0[i] - v1[i];
     }
     return ret;
 }
 
-template <int Dimension> Vector<Dimension> Vector<Dimension>::Scale(const Vector& v, double s)
-{
+template <int Dimension>
+Vector<Dimension> Vector<Dimension>::Scale(const Vector& v, double s) {
     Vector<Dimension> ret;
-    for (int i = 0; i < Dimension; i++) {
+    for(int i = 0; i < Dimension; i++) {
         ret.elem_[i] = v[i] * s;
     }
     return ret;
 }
 
-template <int Dimension> Vector<Dimension> Vector<Dimension>::Divide(const Vector& v, double s)
-{
+template <int Dimension>
+Vector<Dimension> Vector<Dimension>::Divide(const Vector& v, double s) {
     Vector<Dimension> ret;
-    for (int i = 0; i < Dimension; i++) {
+    for(int i = 0; i < Dimension; i++) {
         ret.elem_[i] = v[i] / s;
     }
     return ret;

+ 12 - 9
tracking/util/vectorutils.h

@@ -37,19 +37,22 @@ double Dot(const Vector<4>& v0, const Vector<4>& v1);
 Vector<3> Cross(const Vector<3>& v0, const Vector<3>& v1);
 
 // Returns the square of the length of a Vector.
-template <int Dimension> double LengthSquared(const Vector<Dimension>& v) { return Dot(v, v); }
+template <int Dimension>
+double LengthSquared(const Vector<Dimension>& v) {
+    return Dot(v, v);
+}
 
 // Returns the geometric length of a Vector.
-template <int Dimension> double Length(const Vector<Dimension>& v)
-{
+template <int Dimension>
+double Length(const Vector<Dimension>& v) {
     return sqrt(LengthSquared(v));
 }
 
 // the Vector untouched and returns false.
-template <int Dimension> bool Normalize(Vector<Dimension>* v)
-{
+template <int Dimension>
+bool Normalize(Vector<Dimension>* v) {
     const double len = Length(*v);
-    if (len == 0) {
+    if(len == 0) {
         return false;
     } else {
         (*v) /= len;
@@ -59,10 +62,10 @@ template <int Dimension> bool Normalize(Vector<Dimension>* v)
 
 // Returns a unit-length version of a Vector. If the given Vector has no
 // length, this returns a Zero() Vector.
-template <int Dimension> Vector<Dimension> Normalized(const Vector<Dimension>& v)
-{
+template <int Dimension>
+Vector<Dimension> Normalized(const Vector<Dimension>& v) {
     Vector<Dimension> result = v;
-    if (Normalize(&result))
+    if(Normalize(&result))
         return result;
     else
         return Vector<Dimension>::Zero();

+ 16 - 15
views/bt_mouse.c

@@ -32,25 +32,25 @@ static void bt_mouse_draw_callback(Canvas* canvas, void* context) {
 static void bt_mouse_process(BtMouse* bt_mouse, InputEvent* event) {
     with_view_model(
         bt_mouse->view,
-        void * model,
+        void* model,
         {
             UNUSED(model);
-            if (event->key == InputKeyUp) {
-                if (event->type == InputTypePress) {
+            if(event->key == InputKeyUp) {
+                if(event->type == InputTypePress) {
                     furi_hal_bt_hid_mouse_press(HID_MOUSE_BTN_LEFT);
-                } else if (event->type == InputTypeRelease) {
+                } else if(event->type == InputTypeRelease) {
                     furi_hal_bt_hid_mouse_release(HID_MOUSE_BTN_LEFT);
                 }
-            } else if (event->key == InputKeyDown) {
-                if (event->type == InputTypePress) {
+            } else if(event->key == InputKeyDown) {
+                if(event->type == InputTypePress) {
                     furi_hal_bt_hid_mouse_press(HID_MOUSE_BTN_RIGHT);
-                } else if (event->type == InputTypeRelease) {
+                } else if(event->type == InputTypeRelease) {
                     furi_hal_bt_hid_mouse_release(HID_MOUSE_BTN_RIGHT);
                 }
-            } else if (event->key == InputKeyOk) {
-                if (event->type == InputTypePress) {
+            } else if(event->key == InputKeyOk) {
+                if(event->type == InputTypePress) {
                     furi_hal_bt_hid_mouse_press(HID_MOUSE_BTN_WHEEL);
-                } else if (event->type == InputTypeRelease) {
+                } else if(event->type == InputTypeRelease) {
                     furi_hal_bt_hid_mouse_release(HID_MOUSE_BTN_WHEEL);
                 }
             }
@@ -63,7 +63,7 @@ static bool bt_mouse_input_callback(InputEvent* event, void* context) {
     BtMouse* bt_mouse = context;
     bool consumed = false;
 
-    if (event->type == InputTypeLong && event->key == InputKeyBack) {
+    if(event->type == InputTypeLong && event->key == InputKeyBack) {
         furi_hal_bt_hid_mouse_release_all();
     } else {
         bt_mouse_process(bt_mouse, event);
@@ -78,7 +78,7 @@ void bt_mouse_connection_status_changed_callback(BtStatus status, void* context)
     BtMouse* bt_mouse = context;
 
     bool connected = (status == BtStatusConnected);
-    if (connected) {
+    if(connected) {
         notification_internal_message(bt_mouse->notifications, &sequence_set_blue_255);
     } else {
         notification_internal_message(bt_mouse->notifications, &sequence_reset_blue);
@@ -88,13 +88,14 @@ void bt_mouse_connection_status_changed_callback(BtStatus status, void* context)
     //    bt_mouse->view, void * model, { model->connected = connected; }, true);
 }
 
-void bt_mouse_enter_callback(void *context) {
+void bt_mouse_enter_callback(void* context) {
     furi_assert(context);
     BtMouse* bt_mouse = context;
 
     bt_mouse->bt = furi_record_open(RECORD_BT);
     bt_mouse->notifications = furi_record_open(RECORD_NOTIFICATION);
-    bt_set_status_changed_callback(bt_mouse->bt, bt_mouse_connection_status_changed_callback, bt_mouse);
+    bt_set_status_changed_callback(
+        bt_mouse->bt, bt_mouse_connection_status_changed_callback, bt_mouse);
     furi_assert(bt_set_profile(bt_mouse->bt, BtProfileHidKeyboard));
     furi_hal_bt_start_advertising();
 
@@ -114,7 +115,7 @@ bool bt_mouse_custom_callback(uint32_t event, void* context) {
     return true;
 }
 
-void bt_mouse_exit_callback(void *context) {
+void bt_mouse_exit_callback(void* context) {
     furi_assert(context);
     BtMouse* bt_mouse = context;
 

+ 1 - 1
views/calibration.c

@@ -31,7 +31,7 @@ bool calibration_custom_callback(uint32_t event, void* context) {
     furi_assert(context);
     Calibration* calibration = context;
 
-    if (calibration_step()) {
+    if(calibration_step()) {
         view_dispatcher_switch_to_view(calibration->view_dispatcher, AirMouseViewSubmenu);
     } else {
         view_dispatcher_send_custom_event(calibration->view_dispatcher, 0);

+ 13 - 13
views/usb_mouse.c

@@ -24,25 +24,25 @@ static void usb_mouse_draw_callback(Canvas* canvas, void* context) {
 static void usb_mouse_process(UsbMouse* usb_mouse, InputEvent* event) {
     with_view_model(
         usb_mouse->view,
-        void * model,
+        void* model,
         {
             UNUSED(model);
-            if (event->key == InputKeyUp) {
-                if (event->type == InputTypePress) {
+            if(event->key == InputKeyUp) {
+                if(event->type == InputTypePress) {
                     furi_hal_hid_mouse_press(HID_MOUSE_BTN_LEFT);
-                } else if (event->type == InputTypeRelease) {
+                } else if(event->type == InputTypeRelease) {
                     furi_hal_hid_mouse_release(HID_MOUSE_BTN_LEFT);
                 }
-            } else if (event->key == InputKeyDown) {
-                if (event->type == InputTypePress) {
+            } else if(event->key == InputKeyDown) {
+                if(event->type == InputTypePress) {
                     furi_hal_hid_mouse_press(HID_MOUSE_BTN_RIGHT);
-                } else if (event->type == InputTypeRelease) {
+                } else if(event->type == InputTypeRelease) {
                     furi_hal_hid_mouse_release(HID_MOUSE_BTN_RIGHT);
                 }
-            } else if (event->key == InputKeyOk) {
-                if (event->type == InputTypePress) {
+            } else if(event->key == InputKeyOk) {
+                if(event->type == InputTypePress) {
                     furi_hal_hid_mouse_press(HID_MOUSE_BTN_WHEEL);
-                } else if (event->type == InputTypeRelease) {
+                } else if(event->type == InputTypeRelease) {
                     furi_hal_hid_mouse_release(HID_MOUSE_BTN_WHEEL);
                 }
             }
@@ -55,7 +55,7 @@ static bool usb_mouse_input_callback(InputEvent* event, void* context) {
     UsbMouse* usb_mouse = context;
     bool consumed = false;
 
-    if (event->type == InputTypeLong && event->key == InputKeyBack) {
+    if(event->type == InputTypeLong && event->key == InputKeyBack) {
         // furi_hal_hid_mouse_release_all();
     } else {
         usb_mouse_process(usb_mouse, event);
@@ -65,7 +65,7 @@ static bool usb_mouse_input_callback(InputEvent* event, void* context) {
     return consumed;
 }
 
-void usb_mouse_enter_callback(void *context) {
+void usb_mouse_enter_callback(void* context) {
     furi_assert(context);
     UsbMouse* usb_mouse = context;
 
@@ -90,7 +90,7 @@ bool usb_mouse_custom_callback(uint32_t event, void* context) {
     return true;
 }
 
-void usb_mouse_exit_callback(void *context) {
+void usb_mouse_exit_callback(void* context) {
     furi_assert(context);
     UsbMouse* usb_mouse = context;
 

Некоторые файлы не были показаны из-за большого количества измененных файлов