From: Adrian Fluturel <fluturel.adrian@gmail.com>
To: Frank Li <Frank.Li@nxp.com>
Cc: Jonathan Cameron <jic23@kernel.org>,
David Lechner <dlechner@baylibre.com>,
linux-iio@vger.kernel.org
Subject: Re: [PATCH v2 4/4] iio: magnetometer: Add mmc5633 sensor
Date: Wed, 24 Sep 2025 23:22:15 +0200 [thread overview]
Message-ID: <aNRhBw2lKgsvEEDL@flu-Virtual-Machine> (raw)
In-Reply-To: <20250924-i3c_ddr-v2-4-682a0eb32572@nxp.com>
On Wed, Sep 24, 2025 at 10:30:05AM -0400, Frank Li wrote:
> Add mmc5633 sensor basic support.
> - Support read 20 bits X/Y/Z magnetic.
> - Support I3C HDR mode to send start measurememt command.
> - Support I3C HDR mode to read all sensors data by one command.
>
> Co-developed-by: Carlos Song <carlos.song@nxp.com>
> Signed-off-by: Carlos Song <carlos.song@nxp.com>
> Signed-off-by: Frank Li <Frank.Li@nxp.com>
> ---
> change in v2
> - new patch
> ---
> drivers/iio/magnetometer/Kconfig | 12 +
> drivers/iio/magnetometer/Makefile | 1 +
> drivers/iio/magnetometer/mmc5633.c | 543 +++++++++++++++++++++++++++++++++++++
> 3 files changed, 556 insertions(+)
>
> diff --git a/drivers/iio/magnetometer/Kconfig b/drivers/iio/magnetometer/Kconfig
> index 81b812a29044e2b0b9ff84889c21aa3ebc20be35..cfb74a4a083630678a1db1132a14264de451a31a 100644
> --- a/drivers/iio/magnetometer/Kconfig
> +++ b/drivers/iio/magnetometer/Kconfig
> @@ -139,6 +139,18 @@ config MMC35240
> To compile this driver as a module, choose M here: the module
> will be called mmc35240.
>
> +config MMC5633
> + tristate "MEMSIC MMC5633 3-axis magnetic sensor"
> + select REGMAP_I2C
> + select REGMAP_I3C
> + depends on I2C || I3C
> + help
> + Say yes here to build support for the MEMSIC MMC5633 3-axis
> + magnetic sensor.
> +
> + To compile this driver as a module, choose M here: the module
> + will be called mmc5633
> +
> config IIO_ST_MAGN_3AXIS
> tristate "STMicroelectronics magnetometers 3-Axis Driver"
> depends on (I2C || SPI_MASTER) && SYSFS
> diff --git a/drivers/iio/magnetometer/Makefile b/drivers/iio/magnetometer/Makefile
> index dfe970fcacb8664b293af84893f7d3e3e8d7bf7e..5bd227f8c1204bdd8b8a43da180833eedca1457b 100644
> --- a/drivers/iio/magnetometer/Makefile
> +++ b/drivers/iio/magnetometer/Makefile
> @@ -15,6 +15,7 @@ obj-$(CONFIG_BMC150_MAGN_SPI) += bmc150_magn_spi.o
> obj-$(CONFIG_MAG3110) += mag3110.o
> obj-$(CONFIG_HID_SENSOR_MAGNETOMETER_3D) += hid-sensor-magn-3d.o
> obj-$(CONFIG_MMC35240) += mmc35240.o
> +obj-$(CONFIG_MMC5633) += mmc5633.o
>
> obj-$(CONFIG_IIO_ST_MAGN_3AXIS) += st_magn.o
> st_magn-y := st_magn_core.o
> diff --git a/drivers/iio/magnetometer/mmc5633.c b/drivers/iio/magnetometer/mmc5633.c
> new file mode 100644
> index 0000000000000000000000000000000000000000..b1a6973ea175634bbc2247ff84488ea5393eba0e
> --- /dev/null
> +++ b/drivers/iio/magnetometer/mmc5633.c
> @@ -0,0 +1,543 @@
> +// SPDX-License-Identifier: GPL-2.0-only
> +/*
> + * MMC5633 - MEMSIC 3-axis Magnetic Sensor
> + *
> + * Copyright (c) 2015, Intel Corporation.
> + * Copyright (c) 2025, NXP
> + *
> + * IIO driver for MMC5633, base on mmc35240.c
> + *
> + */
> +
> +#include <linux/delay.h>
> +#include <linux/i2c.h>
> +#include <linux/i3c/device.h>
> +#include <linux/iio/iio.h>
> +#include <linux/iio/sysfs.h>
> +#include <linux/init.h>
> +#include <linux/iopoll.h>
> +#include <linux/module.h>
> +#include <linux/mod_devicetable.h>
> +#include <linux/pm.h>
> +#include <linux/regmap.h>
> +
> +#define MMC5633_REG_XOUT_L 0x00
> +#define MMC5633_REG_XOUT_H 0x01
> +#define MMC5633_REG_YOUT_L 0x02
> +#define MMC5633_REG_YOUT_H 0x03
> +#define MMC5633_REG_ZOUT_L 0x04
> +#define MMC5633_REG_ZOUT_H 0x05
> +#define MMC5633_REG_XOUT_2 0x06
> +#define MMC5633_REG_YOUT_2 0x07
> +#define MMC5633_REG_ZOUT_2 0x08
> +
> +#define MMC5633_REG_STATUS1 0x18
> +#define MMC5633_REG_STATUS0 0x19
> +#define MMC5633_REG_CTRL0 0x1b
> +#define MMC5633_REG_CTRL1 0x1c
> +#define MMC5633_REG_CTRL2 0x1d
> +
> +#define MMC5633_REG_ID 0x39
> +
> +#define MMC5633_STATUS1_MEAS_M_DONE_BIT BIT(6)
> +
> +#define MMC5633_CTRL0_CMM_FREQ_EN BIT(7)
> +#define MMC5633_CTRL0_AUTO_ST_EN BIT(6)
> +#define MMC5633_CTRL0_AUTO_SR_EN BIT(5)
> +#define MMC5633_CTRL0_RESET BIT(4)
> +#define MMC5633_CTRL0_SET BIT(3)
> +#define MMC5633_CTRL0_MEAS_T BIT(1)
> +#define MMC5633_CTRL0_MEAS_M BIT(0)
> +
> +#define MMC5633_CTRL1_BW0_BIT BIT(0)
> +#define MMC5633_CTRL1_BW1_BIT BIT(1)
> +
> +#define MMC5633_CTRL1_BW_MASK (MMC5633_CTRL1_BW0_BIT | \
> + MMC5633_CTRL1_BW1_BIT)
> +
> +#define MMC5633_WAIT_CHARGE_PUMP 50000 /* us */
> +#define MMC5633_WAIT_SET_RESET 1000 /* us */
> +
> +#define MMC5633_HDR_CTRL0_MEAS_M 0x01
> +#define MMC5633_HDR_CTRL0_MEAS_T 0x03
> +#define MMC5633_HDR_CTRL0_SET 0X05
> +#define MMC5633_HDR_CTRL0_RESET 0x07
> +
> +enum mmc5633_axis {
> + AXIS_X,
> + AXIS_Y,
> + AXIS_Z,
> +};
> +
> +struct mmc5633_data {
> + struct device *dev;
> + struct i3c_device *i3cdev;
> + struct mutex mutex; /* protect to finish one whole measurement */
> + struct regmap *regmap;
> +};
> +
> +static const struct {
> + int val;
> + int val2;
> +} mmc5633_samp_freq[] = { {1, 200000},
> + {2, 0},
> + {3, 500000},
> + {6, 600000},
> + };
> +
> +static IIO_CONST_ATTR_SAMP_FREQ_AVAIL("1.2 2.0 3.5 6.6");
> +
> +#define MMC5633_CHANNEL(_axis) { \
> + .type = IIO_MAGN, \
> + .modified = 1, \
> + .channel2 = IIO_MOD_ ## _axis, \
> + .address = AXIS_ ## _axis, \
> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \
> + .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SAMP_FREQ) | \
> + BIT(IIO_CHAN_INFO_SCALE), \
> +}
> +
> +static const struct iio_chan_spec mmc5633_channels[] = {
> + MMC5633_CHANNEL(X),
> + MMC5633_CHANNEL(Y),
> + MMC5633_CHANNEL(Z),
> +};
> +
> +static struct attribute *mmc5633_attributes[] = {
> + &iio_const_attr_sampling_frequency_available.dev_attr.attr,
> + NULL
> +};
> +
> +static const struct attribute_group mmc5633_attribute_group = {
> + .attrs = mmc5633_attributes,
> +};
> +
> +static int mmc5633_get_samp_freq_index(struct mmc5633_data *data,
> + int val, int val2)
> +{
> + int i;
> +
> + for (i = 0; i < ARRAY_SIZE(mmc5633_samp_freq); i++)
> + if (mmc5633_samp_freq[i].val == val &&
> + mmc5633_samp_freq[i].val2 == val2)
> + return i;
> + return -EINVAL;
> +}
> +
> +static int mmc5633_hw_set(struct mmc5633_data *data, bool set)
> +{
> + u8 coil_bit;
> +
> + if (set)
> + coil_bit = MMC5633_CTRL0_SET;
> + else
> + coil_bit = MMC5633_CTRL0_RESET;
> +
> + return regmap_write(data->regmap, MMC5633_REG_CTRL0, coil_bit);
> +}
> +
> +static int mmc5633_init(struct mmc5633_data *data)
> +{
> + unsigned int reg_id, ret;
> +
> + ret = regmap_read(data->regmap, MMC5633_REG_ID, ®_id);
> + if (ret < 0)
> + return dev_err_probe(data->dev, ret,
> + "Error reading product id\n");
> +
> + /*
> + * make sure we restore sensor characteristics, by doing
> + * a SET/RESET sequence, the axis polarity being naturally
> + * aligned after RESET
> + */
> + ret = mmc5633_hw_set(data, true);
> + if (ret < 0)
> + return ret;
> +
> + usleep_range(MMC5633_WAIT_SET_RESET, MMC5633_WAIT_SET_RESET + 1);
> +
> + ret = mmc5633_hw_set(data, false);
> + if (ret < 0)
> + return ret;
> +
> + /* set default sampling frequency */
> + ret = regmap_update_bits(data->regmap, MMC5633_REG_CTRL1,
> + MMC5633_CTRL1_BW_MASK,
> + FIELD_PREP(MMC5633_CTRL1_BW_MASK, 0));
> + if (ret < 0)
> + return ret;
> +
> + return 0;
> +}
> +
> +static int mmc5633_take_measurement(struct mmc5633_data *data)
> +{
> + unsigned int reg_status;
> + int ret;
> +
> + ret = regmap_write(data->regmap, MMC5633_REG_CTRL0, MMC5633_CTRL0_MEAS_M);
> + if (ret < 0)
> + return ret;
> +
> + ret = regmap_read_poll_timeout(data->regmap, MMC5633_REG_STATUS1, reg_status,
> + reg_status & MMC5633_STATUS1_MEAS_M_DONE_BIT,
> + 10000, 10000 * 100);
> +
> + if (ret) {
> + dev_err(data->dev, "data not ready\n");
> + return -EIO;
> + }
> +
> + return 0;
> +}
> +
> +static int mmc5633_read_measurement(struct mmc5633_data *data, void *buf, size_t sz)
> +{
> + __le16 data_word;
> + __le16 status;
> + int ret, val;
> +
> + if (data->i3cdev &&
> + (i3c_device_get_supported_xfer_mode(data->i3cdev) & BIT(I3C_HDR_DDR))) {
> + struct i3c_xfer xfers_wr_cmd[] = {
> + {
> + .cmd = 0x3b,
> + .len = 2,
> + .data.out = &data_word,
> + }
> + };
> +
> + struct i3c_xfer xfers_rd_sta_cmd[] = {
> + {
> + .cmd = 0x23 | BIT(7), /* RDSTA CMD */
> + .len = 2,
> + .data.in = &status,
> + },
> + };
> +
> + struct i3c_xfer xfers_rd_data_cmd[] = {
> + {
> + .cmd = 0x22 | BIT(7), /* RDLONG CMD */
> + .len = sz,
> + .data.in = buf,
> + },
> + };
> +
> + data_word = cpu_to_le16(MMC5633_HDR_CTRL0_MEAS_M << 8);
> +
> + ret = i3c_device_do_xfers(data->i3cdev, xfers_wr_cmd, 1, I3C_HDR_DDR);
> + if (ret < 0)
> + return ret;
> +
> + ret = read_poll_timeout(i3c_device_do_xfers, val,
> + val ||
> + (le16_to_cpu(status) & MMC5633_STATUS1_MEAS_M_DONE_BIT),
> + 10000, 10000 * 100, 0,
> + data->i3cdev, xfers_rd_sta_cmd, 1, I3C_HDR_DDR);
> +
> + if (ret || val) {
> + dev_err(data->dev, "data not ready\n");
> + return -EIO;
> + }
> +
> + return i3c_device_do_xfers(data->i3cdev, xfers_rd_data_cmd, 1, I3C_HDR_DDR);
> + }
> +
> + /* Fallback to use SDR/I2C mode */
> + ret = mmc5633_take_measurement(data);
> + if (ret < 0)
> + return ret;
> +
> + return regmap_bulk_read(data->regmap, MMC5633_REG_XOUT_L, buf, sz);
> +}
> +
> +static int mmc5633_get_raw(struct mmc5633_data *data, int index, unsigned char *buf, int *val)
> +{
> + /*
> + * X[19..12] X[11..4] Y[19..12] Y[11..4] Z[19..12] Z[11..4] X[3..0] Y[3..0] Z[3..0]
> + */
> + *val = buf[2 * index];
> + *val <<= 8;
> +
> + *val |= buf[2 * index + 1];
> + *val <<= 8;
> +
> + *val |= buf[index + 6];
> +
> + *val >>= 4;
> +
> + return 0;
> +}
> +
> +#define MMC5633_ALL_SIZE (3 * 3 + 1) /* each channel have 3 byte and TEMP */
> +
> +static int mmc5633_read_raw(struct iio_dev *indio_dev,
> + struct iio_chan_spec const *chan, int *val,
> + int *val2, long mask)
> +{
> + struct mmc5633_data *data = iio_priv(indio_dev);
> + char buf[MMC5633_ALL_SIZE];
> + unsigned int reg;
> + int ret, i;
> +
> + switch (mask) {
> + case IIO_CHAN_INFO_RAW:
> + scoped_guard(mutex, &data->mutex) {
> + ret = mmc5633_read_measurement(data, buf, MMC5633_ALL_SIZE);
> + if (ret < 0)
> + return ret;
> + }
> +
> + ret = mmc5633_get_raw(data, chan->address, buf, val);
> + if (ret < 0)
> + return ret;
> + return IIO_VAL_INT;
> + case IIO_CHAN_INFO_SCALE:
> + *val = 0;
> + *val2 = 62500;
> + return IIO_VAL_INT_PLUS_NANO;
> + case IIO_CHAN_INFO_SAMP_FREQ:
> + scoped_guard(mutex, &data->mutex) {
> + ret = regmap_read(data->regmap, MMC5633_REG_CTRL1, ®);
> + if (ret < 0)
> + return ret;
> + }
> +
> + i = FIELD_GET(MMC5633_CTRL1_BW_MASK, reg);
> + if (i < 0 || i >= ARRAY_SIZE(mmc5633_samp_freq))
> + return -EINVAL;
> +
> + *val = mmc5633_samp_freq[i].val;
> + *val2 = mmc5633_samp_freq[i].val2;
> + return IIO_VAL_INT_PLUS_MICRO;
> + default:
> + return -EINVAL;
> + }
> +}
> +
> +static int mmc5633_write_raw(struct iio_dev *indio_dev,
> + struct iio_chan_spec const *chan, int val,
> + int val2, long mask)
> +{
> + struct mmc5633_data *data = iio_priv(indio_dev);
> + int i, ret;
> +
> + switch (mask) {
> + case IIO_CHAN_INFO_SAMP_FREQ:
> + i = mmc5633_get_samp_freq_index(data, val, val2);
> + if (i < 0)
> + return -EINVAL;
> +
> + scoped_guard(mutex, &data->mutex) {
> + ret = regmap_update_bits(data->regmap, MMC5633_REG_CTRL1,
> + MMC5633_CTRL1_BW_MASK,
> + FIELD_PREP(MMC5633_CTRL1_BW_MASK, i));
> + if (ret)
> + return ret;
> + };
> + return ret;
> + default:
> + return -EINVAL;
> + }
> +}
> +
> +static const struct iio_info mmc5633_info = {
> + .read_raw = mmc5633_read_raw,
> + .write_raw = mmc5633_write_raw,
> + .attrs = &mmc5633_attribute_group,
> +};
> +
> +static bool mmc5633_is_writeable_reg(struct device *dev, unsigned int reg)
> +{
> + switch (reg) {
> + case MMC5633_REG_CTRL0:
> + case MMC5633_REG_CTRL1:
> + return true;
> + default:
> + return false;
> + }
> +}
> +
> +static bool mmc5633_is_readable_reg(struct device *dev, unsigned int reg)
> +{
> + switch (reg) {
> + case MMC5633_REG_XOUT_L:
> + case MMC5633_REG_XOUT_H:
> + case MMC5633_REG_YOUT_L:
> + case MMC5633_REG_YOUT_H:
> + case MMC5633_REG_ZOUT_L:
> + case MMC5633_REG_ZOUT_H:
> + case MMC5633_REG_XOUT_2:
> + case MMC5633_REG_YOUT_2:
> + case MMC5633_REG_ZOUT_2:
> + case MMC5633_REG_STATUS1:
> + case MMC5633_REG_ID:
> + return true;
> + default:
> + return false;
> + }
> +}
> +
> +static bool mmc5633_is_volatile_reg(struct device *dev, unsigned int reg)
> +{
> + switch (reg) {
> + case MMC5633_REG_CTRL0:
> + case MMC5633_REG_CTRL1:
> + return false;
> + default:
> + return true;
> + }
> +}
> +
> +static const struct reg_default mmc5633_reg_defaults[] = {
> + { MMC5633_REG_CTRL0, 0x00 },
> + { MMC5633_REG_CTRL1, 0x00 },
> +};
> +
> +static const struct regmap_config mmc5633_regmap_config = {
> + .name = "mmc5633_regmap",
> +
> + .reg_bits = 8,
> + .val_bits = 8,
> +
> + .max_register = MMC5633_REG_ID,
> + .cache_type = REGCACHE_FLAT,
> +
> + .writeable_reg = mmc5633_is_writeable_reg,
> + .readable_reg = mmc5633_is_readable_reg,
> + .volatile_reg = mmc5633_is_volatile_reg,
> +
> + .reg_defaults = mmc5633_reg_defaults,
> + .num_reg_defaults = ARRAY_SIZE(mmc5633_reg_defaults),
> +};
> +
> +static int mmc5633_common_probe(struct device *dev, struct regmap *regmap,
> + char *name, struct i3c_device *i3cdev)
> +{
> + struct mmc5633_data *data;
> + struct iio_dev *indio_dev;
> + int ret;
> +
> + indio_dev = devm_iio_device_alloc(dev, sizeof(*data));
> + if (!indio_dev)
> + return -ENOMEM;
> +
> + dev_set_drvdata(dev, indio_dev);
> +
> + data = iio_priv(indio_dev);
> +
> + data->regmap = regmap;
> + data->i3cdev = i3cdev;
> + data->dev = dev;
> +
> + ret = devm_mutex_init(dev, &data->mutex);
> + if (ret)
> + return ret;
> +
> + indio_dev->info = &mmc5633_info;
> + indio_dev->name = name;
> + indio_dev->channels = mmc5633_channels;
> + indio_dev->num_channels = ARRAY_SIZE(mmc5633_channels);
> + indio_dev->modes = INDIO_DIRECT_MODE;
> +
> + ret = mmc5633_init(data);
> + if (ret < 0)
> + return dev_err_probe(dev, ret, "mmc5633 chip init failed\n");
> +
> + return devm_iio_device_register(dev, indio_dev);
> +}
> +
> +static int mmc5633_suspend(struct device *dev)
> +{
> + struct mmc5633_data *data = iio_priv(dev_get_drvdata(dev));
> +
> + regcache_cache_only(data->regmap, true);
> +
> + return 0;
> +}
> +
> +static int mmc5633_resume(struct device *dev)
> +{
> + struct mmc5633_data *data = iio_priv(dev_get_drvdata(dev));
> + int ret;
> +
> + regcache_mark_dirty(data->regmap);
> + ret = regcache_sync_region(data->regmap, MMC5633_REG_CTRL0,
> + MMC5633_REG_CTRL1);
> + if (ret < 0)
> + dev_err(dev, "Failed to restore control registers\n");
> +
> + regcache_cache_only(data->regmap, false);
> +
> + return 0;
> +}
> +
> +static int mmc5633_i2c_probe(struct i2c_client *client)
> +{
> + struct device *dev = &client->dev;
> + struct regmap *regmap;
> +
> + regmap = devm_regmap_init_i2c(client, &mmc5633_regmap_config);
> + if (IS_ERR(regmap))
> + return dev_err_probe(dev, PTR_ERR(regmap), "regmap init failed");
> +
> + return mmc5633_common_probe(dev, regmap, client->name, NULL);
> +}
> +
> +static DEFINE_SIMPLE_DEV_PM_OPS(mmc5633_pm_ops, mmc5633_suspend,
> + mmc5633_resume);
> +
> +static const struct of_device_id mmc5633_of_match[] = {
> + { .compatible = "memsic,mmc5633", },
> + { }
> +};
> +MODULE_DEVICE_TABLE(of, mmc5633_of_match);
> +
> +static const struct i2c_device_id mmc5633_i2c_id[] = {
> + { "mmc5633" },
> + {}
> +};
> +MODULE_DEVICE_TABLE(i2c, mmc5633_i2c_id);
> +
> +static struct i2c_driver mmc5633_i2c_driver = {
> + .driver = {
> + .name = "mmc5633_i2c",
> + .of_match_table = mmc5633_of_match,
> + .pm = pm_sleep_ptr(&mmc5633_pm_ops),
> + },
> + .probe = mmc5633_i2c_probe,
> + .id_table = mmc5633_i2c_id,
> +};
> +
> +static const struct i3c_device_id mmc5633_i3c_ids[] = {
> + I3C_DEVICE(0x0251, 0x0000, NULL),
> + {}
> +};
> +MODULE_DEVICE_TABLE(i3c, mmc5633_i3c_ids);
> +
> +static int mmc5633_i3c_probe(struct i3c_device *i3cdev)
> +{
> + struct device *dev = i3cdev_to_dev(i3cdev);
> + struct regmap *regmap;
> +
> + regmap = devm_regmap_init_i3c(i3cdev, &mmc5633_regmap_config);
> + if (IS_ERR(regmap))
> + return dev_err_probe(dev, PTR_ERR(regmap),
> + "Failed to register i3c regmap\n");
> +
> + return mmc5633_common_probe(dev, regmap, "mmc5633_i3c", i3cdev);
> +}
> +
> +static struct i3c_driver mmc5633_i3c_driver = {
> + .driver = {
> + .name = "mmc5633_i3c",
> + },
> + .probe = mmc5633_i3c_probe,
> + .id_table = mmc5633_i3c_ids,
> +};
> +
> +module_i3c_i2c_driver(mmc5633_i3c_driver, &mmc5633_i2c_driver)
> +
> +MODULE_AUTHOR("Frank Li <Frank.li@nxp.com>");
> +MODULE_DESCRIPTION("MEMSIC MMC5633 magnetic sensor driver");
> +MODULE_LICENSE("GPL");
>
> --
> 2.34.1
>
Hello all,
I've been working on a driver for the MMC 5603NJ using I2C these last few days and it seems to be working. As it happens, I noticed your patch and looked over the datasheet and it seems they are very similar, but your sensor has some extra features. My driver also reads the temperature. I am not experienced enough to tell if they are compatible and if we could merge the drivers in some way. Is there a point to me sending my driver? What is the protocol for situations like these?
I would test your driver to see if it works on my sensor, but there are some features there that my board does not have, so in its current form, I don't think I can use it.
Thank you for your consideration,
- Adrian Fluturel
next prev parent reply other threads:[~2025-09-24 21:22 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-24 14:30 [PATCH v2 0/4] i3c: Add basic HDR mode support Frank Li
2025-09-24 14:30 ` [PATCH v2 1/4] i3c: Add HDR API support Frank Li
2025-09-24 14:30 ` [PATCH v2 2/4] i3c: master: svc: Add basic HDR mode support Frank Li
2025-09-29 15:38 ` Miquel Raynal
2025-09-29 15:55 ` Frank Li
2025-09-29 16:04 ` Miquel Raynal
2025-09-24 14:30 ` [PATCH v2 3/4] dt-bindings: trivial-devices: add MEMSIC 3-axis magnetometer Frank Li
2025-09-24 14:30 ` [PATCH v2 4/4] iio: magnetometer: Add mmc5633 sensor Frank Li
2025-09-24 21:22 ` Adrian Fluturel [this message]
2025-09-25 4:19 ` Frank Li
2025-09-27 18:58 ` Jonathan Cameron
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=aNRhBw2lKgsvEEDL@flu-Virtual-Machine \
--to=fluturel.adrian@gmail.com \
--cc=Frank.Li@nxp.com \
--cc=dlechner@baylibre.com \
--cc=jic23@kernel.org \
--cc=linux-iio@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox