/**
  * struct st_lsm6dsx_settings - ST IMU sensor settings
  * @wai: Sensor WhoAmI default value.
- * @reset_addr: register address for reset/reboot
+ * @reset: register address for reset.
+ * @boot: register address for boot.
+ * @bdu: register address for Block Data Update.
  * @max_fifo_size: Sensor max fifo length in FIFO words.
  * @id: List of hw id/device name supported by the driver configuration.
  * @channels: IIO channels supported by the device.
  */
 struct st_lsm6dsx_settings {
        u8 wai;
-       u8 reset_addr;
+       struct st_lsm6dsx_reg reset;
+       struct st_lsm6dsx_reg boot;
+       struct st_lsm6dsx_reg bdu;
        u16 max_fifo_size;
        struct {
                enum st_lsm6dsx_hw_id hw_id;
 
 #include "st_lsm6dsx.h"
 
 #define ST_LSM6DSX_REG_WHOAMI_ADDR             0x0f
-#define ST_LSM6DSX_REG_RESET_MASK              BIT(0)
-#define ST_LSM6DSX_REG_BOOT_MASK               BIT(7)
-#define ST_LSM6DSX_REG_BDU_ADDR                        0x12
-#define ST_LSM6DSX_REG_BDU_MASK                        BIT(6)
 
 static const struct iio_chan_spec st_lsm6dsx_acc_channels[] = {
        ST_LSM6DSX_CHANNEL_ACC(IIO_ACCEL, 0x28, IIO_MOD_X, 0),
 static const struct st_lsm6dsx_settings st_lsm6dsx_sensor_settings[] = {
        {
                .wai = 0x68,
-               .reset_addr = 0x22,
+               .reset = {
+                       .addr = 0x22,
+                       .mask = BIT(0),
+               },
+               .boot = {
+                       .addr = 0x22,
+                       .mask = BIT(7),
+               },
+               .bdu = {
+                       .addr = 0x22,
+                       .mask = BIT(6),
+               },
                .max_fifo_size = 32,
                .id = {
                        {
        },
        {
                .wai = 0x69,
-               .reset_addr = 0x12,
+               .reset = {
+                       .addr = 0x12,
+                       .mask = BIT(0),
+               },
+               .boot = {
+                       .addr = 0x12,
+                       .mask = BIT(7),
+               },
+               .bdu = {
+                       .addr = 0x12,
+                       .mask = BIT(6),
+               },
                .max_fifo_size = 1365,
                .id = {
                        {
        },
        {
                .wai = 0x69,
-               .reset_addr = 0x12,
+               .reset = {
+                       .addr = 0x12,
+                       .mask = BIT(0),
+               },
+               .boot = {
+                       .addr = 0x12,
+                       .mask = BIT(7),
+               },
+               .bdu = {
+                       .addr = 0x12,
+                       .mask = BIT(6),
+               },
                .max_fifo_size = 682,
                .id = {
                        {
        },
        {
                .wai = 0x6a,
-               .reset_addr = 0x12,
+               .reset = {
+                       .addr = 0x12,
+                       .mask = BIT(0),
+               },
+               .boot = {
+                       .addr = 0x12,
+                       .mask = BIT(7),
+               },
+               .bdu = {
+                       .addr = 0x12,
+                       .mask = BIT(6),
+               },
                .max_fifo_size = 682,
                .id = {
                        {
        },
        {
                .wai = 0x6c,
-               .reset_addr = 0x12,
+               .reset = {
+                       .addr = 0x12,
+                       .mask = BIT(0),
+               },
+               .boot = {
+                       .addr = 0x12,
+                       .mask = BIT(7),
+               },
+               .bdu = {
+                       .addr = 0x12,
+                       .mask = BIT(6),
+               },
                .max_fifo_size = 512,
                .id = {
                        {
        },
        {
                .wai = 0x6b,
-               .reset_addr = 0x12,
+               .reset = {
+                       .addr = 0x12,
+                       .mask = BIT(0),
+               },
+               .boot = {
+                       .addr = 0x12,
+                       .mask = BIT(7),
+               },
+               .bdu = {
+                       .addr = 0x12,
+                       .mask = BIT(6),
+               },
                .max_fifo_size = 512,
                .id = {
                        {
        },
        {
                .wai = 0x6b,
-               .reset_addr = 0x12,
+               .reset = {
+                       .addr = 0x12,
+                       .mask = BIT(0),
+               },
+               .boot = {
+                       .addr = 0x12,
+                       .mask = BIT(7),
+               },
+               .bdu = {
+                       .addr = 0x12,
+                       .mask = BIT(6),
+               },
                .max_fifo_size = 512,
                .id = {
                        {
        int err;
 
        /* device sw reset */
-       err = regmap_update_bits(hw->regmap, hw->settings->reset_addr,
-                                ST_LSM6DSX_REG_RESET_MASK,
-                                FIELD_PREP(ST_LSM6DSX_REG_RESET_MASK, 1));
+       reg = &hw->settings->reset;
+       err = regmap_update_bits(hw->regmap, reg->addr, reg->mask,
+                                ST_LSM6DSX_SHIFT_VAL(1, reg->mask));
        if (err < 0)
                return err;
 
        msleep(50);
 
        /* reload trimming parameter */
-       err = regmap_update_bits(hw->regmap, hw->settings->reset_addr,
-                                ST_LSM6DSX_REG_BOOT_MASK,
-                                FIELD_PREP(ST_LSM6DSX_REG_BOOT_MASK, 1));
+       reg = &hw->settings->boot;
+       err = regmap_update_bits(hw->regmap, reg->addr, reg->mask,
+                                ST_LSM6DSX_SHIFT_VAL(1, reg->mask));
        if (err < 0)
                return err;
 
        msleep(50);
 
        /* enable Block Data Update */
-       err = regmap_update_bits(hw->regmap, ST_LSM6DSX_REG_BDU_ADDR,
-                                ST_LSM6DSX_REG_BDU_MASK,
-                                FIELD_PREP(ST_LSM6DSX_REG_BDU_MASK, 1));
+       reg = &hw->settings->bdu;
+       err = regmap_update_bits(hw->regmap, reg->addr, reg->mask,
+                                ST_LSM6DSX_SHIFT_VAL(1, reg->mask));
        if (err < 0)
                return err;