Refactor the control of measurement and standby modes for the sensor.
Instead of directly writing to the register, encapsulate this operation
in a dedicated function that handles enabling and disabling measurement.
This approach will reduce code duplication wherever sensor configuration
changes are required. In subsequent patches, measurement mode will be
set to standby as part of this process.
Additionally, simplify the control mask to include only the measurement
bit. The sleep bit governs a different behavior—putting the sensor into
sleep mode, not just standby for configuration—and is currently unused.
Therefore, there's no need to include both the sleep and measurement
bits in the same mask.
Reviewed-by: Andy Shevchenko <andy@kernel.org>
Signed-off-by: Lothar Rubusch <l.rubusch@gmail.com>
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://patch.msgid.link/20250702230819.19353-3-l.rubusch@gmail.com
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
 #define ADXL313_RATE_MSK               GENMASK(3, 0)
 #define ADXL313_RATE_BASE              6
 
-#define ADXL313_POWER_CTL_MSK          GENMASK(3, 2)
-#define ADXL313_MEASUREMENT_MODE       BIT(3)
+#define ADXL313_POWER_CTL_MSK          BIT(3)
 
 #define ADXL313_RANGE_MSK              GENMASK(1, 0)
 #define ADXL313_RANGE_MAX              3
 
 }
 EXPORT_SYMBOL_NS_GPL(adxl313_is_volatile_reg, "IIO_ADXL313");
 
+static int adxl313_set_measure_en(struct adxl313_data *data, bool en)
+{
+       return regmap_assign_bits(data->regmap, ADXL313_REG_POWER_CTL,
+                                 ADXL313_POWER_CTL_MSK, en);
+}
+
 static int adxl312_check_id(struct device *dev,
                            struct adxl313_data *data)
 {
        }
 
        /* Enables measurement mode */
-       return regmap_update_bits(data->regmap, ADXL313_REG_POWER_CTL,
-                                 ADXL313_POWER_CTL_MSK,
-                                 ADXL313_MEASUREMENT_MODE);
+       return adxl313_set_measure_en(data, true);
 }
 
 /**