Re: [PATCH v2 3/3] iio: hmc5843: Move hmc5843 out of staging
From: Daniel Baluta
Date: Mon Feb 22 2016 - 04:08:17 EST
On Sun, Feb 21, 2016 at 10:29 PM, Jonathan Cameron <jic23@xxxxxxxxxx> wrote:
> On 14/02/16 22:37, Cristina Moraru wrote:
>> This patch moves hmc5843 driver from staging/iio/magnetometer
>> to iio/magnetometer, updates the corresponding Makefiles and
>> moves the hmc5843* entries to the 'Industrial I/O support ->
>> Magnetometer sensors' menu.
>>
>> Signed-off-by: Cristina Moraru <cristina.moraru09@xxxxxxxxx>
>> Cc: Daniel Baluta <daniel.baluta@xxxxxxxxx>
> For some reason I couldn't immediately identify this patch wouldn't
> apply to my tree. I hand applied it and all seemed fine, but please do
> sanity check the result - shortly to be in the testing branch of iio.git
>
> Applied. Thanks,
>
Hi,
Most likely is because of this patch:
commit 343af6379e950266ee3d4f638a3ffe0b01b08eab
Author: Bhumika Goyal <bhumirks@xxxxxxxxx>
Date: Fri Feb 12 20:40:29 2016 +0530
Staging: iio: magnetometer: remove exceptional & on function name
In this file,function names are otherwise used as pointers without &.
Found using coccinelle.
// <smpl>
@r@
identifier f;
@@
f(...) { ... }
@@
identifier r.f;
@@
- &f
+ f
// </smpl>
Signed-off-by: Bhumika Goyal <bhumirks@xxxxxxxxx>
Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>
This arrived in IIO tree via Greg's staging tree rebase. So, now the
changes done be
Bhumika are reverted.
The simplest solution would be for Bhumika to resend her patch rebased
on linux-iio
tree on testing branch.
> Jonathan
>> ---
>> Changes since v1:
>> No change since v1
>> drivers/iio/magnetometer/Kconfig | 33 ++
>> drivers/iio/magnetometer/Makefile | 4 +
>> drivers/iio/magnetometer/hmc5843.h | 65 +++
>> drivers/iio/magnetometer/hmc5843_core.c | 686 ++++++++++++++++++++++++
>> drivers/iio/magnetometer/hmc5843_i2c.c | 103 ++++
>> drivers/iio/magnetometer/hmc5843_spi.c | 100 ++++
>> drivers/staging/iio/magnetometer/Kconfig | 32 --
>> drivers/staging/iio/magnetometer/Makefile | 4 +-
>> drivers/staging/iio/magnetometer/hmc5843.h | 65 ---
>> drivers/staging/iio/magnetometer/hmc5843_core.c | 686 ------------------------
>> drivers/staging/iio/magnetometer/hmc5843_i2c.c | 103 ----
>> drivers/staging/iio/magnetometer/hmc5843_spi.c | 100 ----
>> 12 files changed, 992 insertions(+), 989 deletions(-)
>> create mode 100644 drivers/iio/magnetometer/hmc5843.h
>> create mode 100644 drivers/iio/magnetometer/hmc5843_core.c
>> create mode 100644 drivers/iio/magnetometer/hmc5843_i2c.c
>> create mode 100644 drivers/iio/magnetometer/hmc5843_spi.c
>> delete mode 100644 drivers/staging/iio/magnetometer/hmc5843.h
>> delete mode 100644 drivers/staging/iio/magnetometer/hmc5843_core.c
>> delete mode 100644 drivers/staging/iio/magnetometer/hmc5843_i2c.c
>> delete mode 100644 drivers/staging/iio/magnetometer/hmc5843_spi.c
>>
>> diff --git a/drivers/iio/magnetometer/Kconfig b/drivers/iio/magnetometer/Kconfig
>> index 868abad..021dc53 100644
>> --- a/drivers/iio/magnetometer/Kconfig
>> +++ b/drivers/iio/magnetometer/Kconfig
>> @@ -105,4 +105,37 @@ config IIO_ST_MAGN_SPI_3AXIS
>> depends on IIO_ST_MAGN_3AXIS
>> depends on IIO_ST_SENSORS_SPI
>>
>> +config SENSORS_HMC5843
>> + tristate
>> + select IIO_BUFFER
>> + select IIO_TRIGGERED_BUFFER
>> +
>> +config SENSORS_HMC5843_I2C
>> + tristate "Honeywell HMC5843/5883/5883L 3-Axis Magnetometer (I2C)"
>> + depends on I2C
>> + select SENSORS_HMC5843
>> + select REGMAP_I2C
>> + help
>> + Say Y here to add support for the Honeywell HMC5843, HMC5883 and
>> + HMC5883L 3-Axis Magnetometer (digital compass).
>> +
>> + This driver can also be compiled as a set of modules.
>> + If so, these modules will be created:
>> + - hmc5843_core (core functions)
>> + - hmc5843_i2c (support for HMC5843, HMC5883, HMC5883L and HMC5983)
>> +
>> +config SENSORS_HMC5843_SPI
>> + tristate "Honeywell HMC5983 3-Axis Magnetometer (SPI)"
>> + depends on SPI_MASTER
>> + select SENSORS_HMC5843
>> + select REGMAP_SPI
>> + help
>> + Say Y here to add support for the Honeywell HMC5983 3-Axis Magnetometer
>> + (digital compass).
>> +
>> + This driver can also be compiled as a set of modules.
>> + If so, these modules will be created:
>> + - hmc5843_core (core functions)
>> + - hmc5843_spi (support for HMC5983)
>> +
>> endmenu
>> diff --git a/drivers/iio/magnetometer/Makefile b/drivers/iio/magnetometer/Makefile
>> index 2c72df4..dd03fe5 100644
>> --- a/drivers/iio/magnetometer/Makefile
>> +++ b/drivers/iio/magnetometer/Makefile
>> @@ -15,3 +15,7 @@ st_magn-$(CONFIG_IIO_BUFFER) += st_magn_buffer.o
>>
>> obj-$(CONFIG_IIO_ST_MAGN_I2C_3AXIS) += st_magn_i2c.o
>> obj-$(CONFIG_IIO_ST_MAGN_SPI_3AXIS) += st_magn_spi.o
>> +
>> +obj-$(CONFIG_SENSORS_HMC5843) += hmc5843_core.o
>> +obj-$(CONFIG_SENSORS_HMC5843_I2C) += hmc5843_i2c.o
>> +obj-$(CONFIG_SENSORS_HMC5843_SPI) += hmc5843_spi.o
>> diff --git a/drivers/iio/magnetometer/hmc5843.h b/drivers/iio/magnetometer/hmc5843.h
>> new file mode 100644
>> index 0000000..76a5d74
>> --- /dev/null
>> +++ b/drivers/iio/magnetometer/hmc5843.h
>> @@ -0,0 +1,65 @@
>> +/*
>> + * Header file for hmc5843 driver
>> + *
>> + * Split from hmc5843.c
>> + * Copyright (C) Josef Gajdusek <atx@xxxxxxxx>
>> + *
>> + * This program is free software; you can redistribute it and/or modify
>> + * it under the terms of the GNU General Public License version 2 as
>> + * published by the Free Software Foundation.
>> + */
>> +
>> +#ifndef HMC5843_CORE_H
>> +#define HMC5843_CORE_H
>> +
>> +#include <linux/regmap.h>
>> +#include <linux/iio/iio.h>
>> +
>> +#define HMC5843_CONFIG_REG_A 0x00
>> +#define HMC5843_CONFIG_REG_B 0x01
>> +#define HMC5843_MODE_REG 0x02
>> +#define HMC5843_DATA_OUT_MSB_REGS 0x03
>> +#define HMC5843_STATUS_REG 0x09
>> +#define HMC5843_ID_REG 0x0a
>> +#define HMC5843_ID_END 0x0c
>> +
>> +enum hmc5843_ids {
>> + HMC5843_ID,
>> + HMC5883_ID,
>> + HMC5883L_ID,
>> + HMC5983_ID,
>> +};
>> +
>> +/**
>> + * struct hcm5843_data - device specific data
>> + * @dev: actual device
>> + * @lock: update and read regmap data
>> + * @regmap: hardware access register maps
>> + * @variant: describe chip variants
>> + * @buffer: 3x 16-bit channels + padding + 64-bit timestamp
>> + */
>> +struct hmc5843_data {
>> + struct device *dev;
>> + struct mutex lock;
>> + struct regmap *regmap;
>> + const struct hmc5843_chip_info *variant;
>> + __be16 buffer[8];
>> +};
>> +
>> +int hmc5843_common_probe(struct device *dev, struct regmap *regmap,
>> + enum hmc5843_ids id, const char *name);
>> +int hmc5843_common_remove(struct device *dev);
>> +
>> +int hmc5843_common_suspend(struct device *dev);
>> +int hmc5843_common_resume(struct device *dev);
>> +
>> +#ifdef CONFIG_PM_SLEEP
>> +static SIMPLE_DEV_PM_OPS(hmc5843_pm_ops,
>> + hmc5843_common_suspend,
>> + hmc5843_common_resume);
>> +#define HMC5843_PM_OPS (&hmc5843_pm_ops)
>> +#else
>> +#define HMC5843_PM_OPS NULL
>> +#endif
>> +
>> +#endif /* HMC5843_CORE_H */
>> diff --git a/drivers/iio/magnetometer/hmc5843_core.c b/drivers/iio/magnetometer/hmc5843_core.c
>> new file mode 100644
>> index 0000000..77882b4
>> --- /dev/null
>> +++ b/drivers/iio/magnetometer/hmc5843_core.c
>> @@ -0,0 +1,686 @@
>> +/*
>> + * Device driver for the the HMC5843 multi-chip module designed
>> + * for low field magnetic sensing.
>> + *
>> + * Copyright (C) 2010 Texas Instruments
>> + *
>> + * Author: Shubhrajyoti Datta <shubhrajyoti@xxxxxx>
>> + * Acknowledgment: Jonathan Cameron <jic23@xxxxxxxxxx> for valuable inputs.
>> + * Support for HMC5883 and HMC5883L by Peter Meerwald <pmeerw@xxxxxxxxxx>.
>> + * Split to multiple files by Josef Gajdusek <atx@xxxxxxxx> - 2014
>> + *
>> + * This program is free software; you can redistribute it and/or modify
>> + * it under the terms of the GNU General Public License as published by
>> + * the Free Software Foundation; either version 2 of the License, or
>> + * (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
>> + * GNU General Public License for more details.
>> + */
>> +
>> +#include <linux/module.h>
>> +#include <linux/regmap.h>
>> +#include <linux/iio/iio.h>
>> +#include <linux/iio/sysfs.h>
>> +#include <linux/iio/trigger_consumer.h>
>> +#include <linux/iio/buffer.h>
>> +#include <linux/iio/triggered_buffer.h>
>> +#include <linux/delay.h>
>> +
>> +#include "hmc5843.h"
>> +
>> +/*
>> + * Range gain settings in (+-)Ga
>> + * Beware: HMC5843 and HMC5883 have different recommended sensor field
>> + * ranges; default corresponds to +-1.0 Ga and +-1.3 Ga, respectively
>> + */
>> +#define HMC5843_RANGE_GAIN_OFFSET 0x05
>> +#define HMC5843_RANGE_GAIN_DEFAULT 0x01
>> +#define HMC5843_RANGE_GAIN_MASK 0xe0
>> +
>> +/* Device status */
>> +#define HMC5843_DATA_READY 0x01
>> +#define HMC5843_DATA_OUTPUT_LOCK 0x02
>> +
>> +/* Mode register configuration */
>> +#define HMC5843_MODE_CONVERSION_CONTINUOUS 0x00
>> +#define HMC5843_MODE_CONVERSION_SINGLE 0x01
>> +#define HMC5843_MODE_IDLE 0x02
>> +#define HMC5843_MODE_SLEEP 0x03
>> +#define HMC5843_MODE_MASK 0x03
>> +
>> +/*
>> + * HMC5843: Minimum data output rate
>> + * HMC5883: Typical data output rate
>> + */
>> +#define HMC5843_RATE_OFFSET 0x02
>> +#define HMC5843_RATE_DEFAULT 0x04
>> +#define HMC5843_RATE_MASK 0x1c
>> +
>> +/* Device measurement configuration */
>> +#define HMC5843_MEAS_CONF_NORMAL 0x00
>> +#define HMC5843_MEAS_CONF_POSITIVE_BIAS 0x01
>> +#define HMC5843_MEAS_CONF_NEGATIVE_BIAS 0x02
>> +#define HMC5843_MEAS_CONF_MASK 0x03
>> +
>> +/*
>> + * API for setting the measurement configuration to
>> + * Normal, Positive bias and Negative bias
>> + *
>> + * From the datasheet:
>> + * 0 - Normal measurement configuration (default): In normal measurement
>> + * configuration the device follows normal measurement flow. Pins BP
>> + * and BN are left floating and high impedance.
>> + *
>> + * 1 - Positive bias configuration: In positive bias configuration, a
>> + * positive current is forced across the resistive load on pins BP
>> + * and BN.
>> + *
>> + * 2 - Negative bias configuration. In negative bias configuration, a
>> + * negative current is forced across the resistive load on pins BP
>> + * and BN.
>> + *
>> + * 3 - Only available on HMC5983. Magnetic sensor is disabled.
>> + * Temperature sensor is enabled.
>> + */
>> +
>> +static const char *const hmc5843_meas_conf_modes[] = {"normal", "positivebias",
>> + "negativebias"};
>> +
>> +static const char *const hmc5983_meas_conf_modes[] = {"normal", "positivebias",
>> + "negativebias",
>> + "disabled"};
>> +/* Scaling factors: 10000000/Gain */
>> +static const int hmc5843_regval_to_nanoscale[] = {
>> + 6173, 7692, 10309, 12821, 18868, 21739, 25641, 35714
>> +};
>> +
>> +static const int hmc5883_regval_to_nanoscale[] = {
>> + 7812, 9766, 13021, 16287, 24096, 27701, 32573, 45662
>> +};
>> +
>> +static const int hmc5883l_regval_to_nanoscale[] = {
>> + 7299, 9174, 12195, 15152, 22727, 25641, 30303, 43478
>> +};
>> +
>> +/*
>> + * From the datasheet:
>> + * Value | HMC5843 | HMC5883/HMC5883L
>> + * | Data output rate (Hz) | Data output rate (Hz)
>> + * 0 | 0.5 | 0.75
>> + * 1 | 1 | 1.5
>> + * 2 | 2 | 3
>> + * 3 | 5 | 7.5
>> + * 4 | 10 (default) | 15
>> + * 5 | 20 | 30
>> + * 6 | 50 | 75
>> + * 7 | Not used | Not used
>> + */
>> +static const int hmc5843_regval_to_samp_freq[][2] = {
>> + {0, 500000}, {1, 0}, {2, 0}, {5, 0}, {10, 0}, {20, 0}, {50, 0}
>> +};
>> +
>> +static const int hmc5883_regval_to_samp_freq[][2] = {
>> + {0, 750000}, {1, 500000}, {3, 0}, {7, 500000}, {15, 0}, {30, 0},
>> + {75, 0}
>> +};
>> +
>> +static const int hmc5983_regval_to_samp_freq[][2] = {
>> + {0, 750000}, {1, 500000}, {3, 0}, {7, 500000}, {15, 0}, {30, 0},
>> + {75, 0}, {220, 0}
>> +};
>> +
>> +/* Describe chip variants */
>> +struct hmc5843_chip_info {
>> + const struct iio_chan_spec *channels;
>> + const int (*regval_to_samp_freq)[2];
>> + const int n_regval_to_samp_freq;
>> + const int *regval_to_nanoscale;
>> + const int n_regval_to_nanoscale;
>> +};
>> +
>> +/* The lower two bits contain the current conversion mode */
>> +static s32 hmc5843_set_mode(struct hmc5843_data *data, u8 operating_mode)
>> +{
>> + int ret;
>> +
>> + mutex_lock(&data->lock);
>> + ret = regmap_update_bits(data->regmap, HMC5843_MODE_REG,
>> + HMC5843_MODE_MASK, operating_mode);
>> + mutex_unlock(&data->lock);
>> +
>> + return ret;
>> +}
>> +
>> +static int hmc5843_wait_measurement(struct hmc5843_data *data)
>> +{
>> + int tries = 150;
>> + unsigned int val;
>> + int ret;
>> +
>> + while (tries-- > 0) {
>> + ret = regmap_read(data->regmap, HMC5843_STATUS_REG, &val);
>> + if (ret < 0)
>> + return ret;
>> + if (val & HMC5843_DATA_READY)
>> + break;
>> + msleep(20);
>> + }
>> +
>> + if (tries < 0) {
>> + dev_err(data->dev, "data not ready\n");
>> + return -EIO;
>> + }
>> +
>> + return 0;
>> +}
>> +
>> +/* Return the measurement value from the specified channel */
>> +static int hmc5843_read_measurement(struct hmc5843_data *data,
>> + int idx, int *val)
>> +{
>> + __be16 values[3];
>> + int ret;
>> +
>> + mutex_lock(&data->lock);
>> + ret = hmc5843_wait_measurement(data);
>> + if (ret < 0) {
>> + mutex_unlock(&data->lock);
>> + return ret;
>> + }
>> + ret = regmap_bulk_read(data->regmap, HMC5843_DATA_OUT_MSB_REGS,
>> + values, sizeof(values));
>> + mutex_unlock(&data->lock);
>> + if (ret < 0)
>> + return ret;
>> +
>> + *val = sign_extend32(be16_to_cpu(values[idx]), 15);
>> + return IIO_VAL_INT;
>> +}
>> +
>> +static int hmc5843_set_meas_conf(struct hmc5843_data *data, u8 meas_conf)
>> +{
>> + int ret;
>> +
>> + mutex_lock(&data->lock);
>> + ret = regmap_update_bits(data->regmap, HMC5843_CONFIG_REG_A,
>> + HMC5843_MEAS_CONF_MASK, meas_conf);
>> + mutex_unlock(&data->lock);
>> +
>> + return ret;
>> +}
>> +
>> +static
>> +int hmc5843_show_measurement_configuration(struct iio_dev *indio_dev,
>> + const struct iio_chan_spec *chan)
>> +{
>> + struct hmc5843_data *data = iio_priv(indio_dev);
>> + unsigned int val;
>> + int ret;
>> +
>> + ret = regmap_read(data->regmap, HMC5843_CONFIG_REG_A, &val);
>> + if (ret)
>> + return ret;
>> +
>> + return val & HMC5843_MEAS_CONF_MASK;
>> +}
>> +
>> +static
>> +int hmc5843_set_measurement_configuration(struct iio_dev *indio_dev,
>> + const struct iio_chan_spec *chan,
>> + unsigned int meas_conf)
>> +{
>> + struct hmc5843_data *data = iio_priv(indio_dev);
>> +
>> + return hmc5843_set_meas_conf(data, meas_conf);
>> +}
>> +
>> +static const struct iio_enum hmc5843_meas_conf_enum = {
>> + .items = hmc5843_meas_conf_modes,
>> + .num_items = ARRAY_SIZE(hmc5843_meas_conf_modes),
>> + .get = hmc5843_show_measurement_configuration,
>> + .set = hmc5843_set_measurement_configuration,
>> +};
>> +
>> +static const struct iio_chan_spec_ext_info hmc5843_ext_info[] = {
>> + IIO_ENUM("meas_conf", true, &hmc5843_meas_conf_enum),
>> + IIO_ENUM_AVAILABLE("meas_conf", &hmc5843_meas_conf_enum),
>> + { },
>> +};
>> +
>> +static const struct iio_enum hmc5983_meas_conf_enum = {
>> + .items = hmc5983_meas_conf_modes,
>> + .num_items = ARRAY_SIZE(hmc5983_meas_conf_modes),
>> + .get = hmc5843_show_measurement_configuration,
>> + .set = hmc5843_set_measurement_configuration,
>> +};
>> +
>> +static const struct iio_chan_spec_ext_info hmc5983_ext_info[] = {
>> + IIO_ENUM("meas_conf", true, &hmc5983_meas_conf_enum),
>> + IIO_ENUM_AVAILABLE("meas_conf", &hmc5983_meas_conf_enum),
>> + { },
>> +};
>> +
>> +static
>> +ssize_t hmc5843_show_samp_freq_avail(struct device *dev,
>> + struct device_attribute *attr, char *buf)
>> +{
>> + struct hmc5843_data *data = iio_priv(dev_to_iio_dev(dev));
>> + size_t len = 0;
>> + int i;
>> +
>> + for (i = 0; i < data->variant->n_regval_to_samp_freq; i++)
>> + len += scnprintf(buf + len, PAGE_SIZE - len,
>> + "%d.%d ", data->variant->regval_to_samp_freq[i][0],
>> + data->variant->regval_to_samp_freq[i][1]);
>> +
>> + /* replace trailing space by newline */
>> + buf[len - 1] = '\n';
>> +
>> + return len;
>> +}
>> +
>> +static IIO_DEV_ATTR_SAMP_FREQ_AVAIL(hmc5843_show_samp_freq_avail);
>> +
>> +static int hmc5843_set_samp_freq(struct hmc5843_data *data, u8 rate)
>> +{
>> + int ret;
>> +
>> + mutex_lock(&data->lock);
>> + ret = regmap_update_bits(data->regmap, HMC5843_CONFIG_REG_A,
>> + HMC5843_RATE_MASK,
>> + rate << HMC5843_RATE_OFFSET);
>> + mutex_unlock(&data->lock);
>> +
>> + return ret;
>> +}
>> +
>> +static int hmc5843_get_samp_freq_index(struct hmc5843_data *data,
>> + int val, int val2)
>> +{
>> + int i;
>> +
>> + for (i = 0; i < data->variant->n_regval_to_samp_freq; i++)
>> + if (val == data->variant->regval_to_samp_freq[i][0] &&
>> + val2 == data->variant->regval_to_samp_freq[i][1])
>> + return i;
>> +
>> + return -EINVAL;
>> +}
>> +
>> +static int hmc5843_set_range_gain(struct hmc5843_data *data, u8 range)
>> +{
>> + int ret;
>> +
>> + mutex_lock(&data->lock);
>> + ret = regmap_update_bits(data->regmap, HMC5843_CONFIG_REG_B,
>> + HMC5843_RANGE_GAIN_MASK,
>> + range << HMC5843_RANGE_GAIN_OFFSET);
>> + mutex_unlock(&data->lock);
>> +
>> + return ret;
>> +}
>> +
>> +static ssize_t hmc5843_show_scale_avail(struct device *dev,
>> + struct device_attribute *attr,
>> + char *buf)
>> +{
>> + struct hmc5843_data *data = iio_priv(dev_to_iio_dev(dev));
>> +
>> + size_t len = 0;
>> + int i;
>> +
>> + for (i = 0; i < data->variant->n_regval_to_nanoscale; i++)
>> + len += scnprintf(buf + len, PAGE_SIZE - len,
>> + "0.%09d ", data->variant->regval_to_nanoscale[i]);
>> +
>> + /* replace trailing space by newline */
>> + buf[len - 1] = '\n';
>> +
>> + return len;
>> +}
>> +
>> +static IIO_DEVICE_ATTR(scale_available, S_IRUGO,
>> + hmc5843_show_scale_avail, NULL, 0);
>> +
>> +static int hmc5843_get_scale_index(struct hmc5843_data *data, int val, int val2)
>> +{
>> + int i;
>> +
>> + if (val)
>> + return -EINVAL;
>> +
>> + for (i = 0; i < data->variant->n_regval_to_nanoscale; i++)
>> + if (val2 == data->variant->regval_to_nanoscale[i])
>> + return i;
>> +
>> + return -EINVAL;
>> +}
>> +
>> +static int hmc5843_read_raw(struct iio_dev *indio_dev,
>> + struct iio_chan_spec const *chan,
>> + int *val, int *val2, long mask)
>> +{
>> + struct hmc5843_data *data = iio_priv(indio_dev);
>> + unsigned int rval;
>> + int ret;
>> +
>> + switch (mask) {
>> + case IIO_CHAN_INFO_RAW:
>> + return hmc5843_read_measurement(data, chan->scan_index, val);
>> + case IIO_CHAN_INFO_SCALE:
>> + ret = regmap_read(data->regmap, HMC5843_CONFIG_REG_B, &rval);
>> + if (ret < 0)
>> + return ret;
>> + rval >>= HMC5843_RANGE_GAIN_OFFSET;
>> + *val = 0;
>> + *val2 = data->variant->regval_to_nanoscale[rval];
>> + return IIO_VAL_INT_PLUS_NANO;
>> + case IIO_CHAN_INFO_SAMP_FREQ:
>> + ret = regmap_read(data->regmap, HMC5843_CONFIG_REG_A, &rval);
>> + if (ret < 0)
>> + return ret;
>> + rval >>= HMC5843_RATE_OFFSET;
>> + *val = data->variant->regval_to_samp_freq[rval][0];
>> + *val2 = data->variant->regval_to_samp_freq[rval][1];
>> + return IIO_VAL_INT_PLUS_MICRO;
>> + }
>> + return -EINVAL;
>> +}
>> +
>> +static int hmc5843_write_raw(struct iio_dev *indio_dev,
>> + struct iio_chan_spec const *chan,
>> + int val, int val2, long mask)
>> +{
>> + struct hmc5843_data *data = iio_priv(indio_dev);
>> + int rate, range;
>> +
>> + switch (mask) {
>> + case IIO_CHAN_INFO_SAMP_FREQ:
>> + rate = hmc5843_get_samp_freq_index(data, val, val2);
>> + if (rate < 0)
>> + return -EINVAL;
>> +
>> + return hmc5843_set_samp_freq(data, rate);
>> + case IIO_CHAN_INFO_SCALE:
>> + range = hmc5843_get_scale_index(data, val, val2);
>> + if (range < 0)
>> + return -EINVAL;
>> +
>> + return hmc5843_set_range_gain(data, range);
>> + default:
>> + return -EINVAL;
>> + }
>> +}
>> +
>> +static int hmc5843_write_raw_get_fmt(struct iio_dev *indio_dev,
>> + struct iio_chan_spec const *chan,
>> + long mask)
>> +{
>> + switch (mask) {
>> + case IIO_CHAN_INFO_SAMP_FREQ:
>> + return IIO_VAL_INT_PLUS_MICRO;
>> + case IIO_CHAN_INFO_SCALE:
>> + return IIO_VAL_INT_PLUS_NANO;
>> + default:
>> + return -EINVAL;
>> + }
>> +}
>> +
>> +static irqreturn_t hmc5843_trigger_handler(int irq, void *p)
>> +{
>> + struct iio_poll_func *pf = p;
>> + struct iio_dev *indio_dev = pf->indio_dev;
>> + struct hmc5843_data *data = iio_priv(indio_dev);
>> + int ret;
>> +
>> + mutex_lock(&data->lock);
>> + ret = hmc5843_wait_measurement(data);
>> + if (ret < 0) {
>> + mutex_unlock(&data->lock);
>> + goto done;
>> + }
>> +
>> + ret = regmap_bulk_read(data->regmap, HMC5843_DATA_OUT_MSB_REGS,
>> + data->buffer, 3 * sizeof(__be16));
>> +
>> + mutex_unlock(&data->lock);
>> + if (ret < 0)
>> + goto done;
>> +
>> + iio_push_to_buffers_with_timestamp(indio_dev, data->buffer,
>> + iio_get_time_ns());
>> +
>> +done:
>> + iio_trigger_notify_done(indio_dev->trig);
>> +
>> + return IRQ_HANDLED;
>> +}
>> +
>> +#define HMC5843_CHANNEL(axis, idx) \
>> + { \
>> + .type = IIO_MAGN, \
>> + .modified = 1, \
>> + .channel2 = IIO_MOD_##axis, \
>> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \
>> + .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) | \
>> + BIT(IIO_CHAN_INFO_SAMP_FREQ), \
>> + .scan_index = idx, \
>> + .scan_type = { \
>> + .sign = 's', \
>> + .realbits = 16, \
>> + .storagebits = 16, \
>> + .endianness = IIO_BE, \
>> + }, \
>> + .ext_info = hmc5843_ext_info, \
>> + }
>> +
>> +#define HMC5983_CHANNEL(axis, idx) \
>> + { \
>> + .type = IIO_MAGN, \
>> + .modified = 1, \
>> + .channel2 = IIO_MOD_##axis, \
>> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \
>> + .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) | \
>> + BIT(IIO_CHAN_INFO_SAMP_FREQ), \
>> + .scan_index = idx, \
>> + .scan_type = { \
>> + .sign = 's', \
>> + .realbits = 16, \
>> + .storagebits = 16, \
>> + .endianness = IIO_BE, \
>> + }, \
>> + .ext_info = hmc5983_ext_info, \
>> + }
>> +
>> +static const struct iio_chan_spec hmc5843_channels[] = {
>> + HMC5843_CHANNEL(X, 0),
>> + HMC5843_CHANNEL(Y, 1),
>> + HMC5843_CHANNEL(Z, 2),
>> + IIO_CHAN_SOFT_TIMESTAMP(3),
>> +};
>> +
>> +/* Beware: Y and Z are exchanged on HMC5883 and 5983 */
>> +static const struct iio_chan_spec hmc5883_channels[] = {
>> + HMC5843_CHANNEL(X, 0),
>> + HMC5843_CHANNEL(Z, 1),
>> + HMC5843_CHANNEL(Y, 2),
>> + IIO_CHAN_SOFT_TIMESTAMP(3),
>> +};
>> +
>> +static const struct iio_chan_spec hmc5983_channels[] = {
>> + HMC5983_CHANNEL(X, 0),
>> + HMC5983_CHANNEL(Z, 1),
>> + HMC5983_CHANNEL(Y, 2),
>> + IIO_CHAN_SOFT_TIMESTAMP(3),
>> +};
>> +
>> +static struct attribute *hmc5843_attributes[] = {
>> + &iio_dev_attr_scale_available.dev_attr.attr,
>> + &iio_dev_attr_sampling_frequency_available.dev_attr.attr,
>> + NULL
>> +};
>> +
>> +static const struct attribute_group hmc5843_group = {
>> + .attrs = hmc5843_attributes,
>> +};
>> +
>> +static const struct hmc5843_chip_info hmc5843_chip_info_tbl[] = {
>> + [HMC5843_ID] = {
>> + .channels = hmc5843_channels,
>> + .regval_to_samp_freq = hmc5843_regval_to_samp_freq,
>> + .n_regval_to_samp_freq =
>> + ARRAY_SIZE(hmc5843_regval_to_samp_freq),
>> + .regval_to_nanoscale = hmc5843_regval_to_nanoscale,
>> + .n_regval_to_nanoscale =
>> + ARRAY_SIZE(hmc5843_regval_to_nanoscale),
>> + },
>> + [HMC5883_ID] = {
>> + .channels = hmc5883_channels,
>> + .regval_to_samp_freq = hmc5883_regval_to_samp_freq,
>> + .n_regval_to_samp_freq =
>> + ARRAY_SIZE(hmc5883_regval_to_samp_freq),
>> + .regval_to_nanoscale = hmc5883_regval_to_nanoscale,
>> + .n_regval_to_nanoscale =
>> + ARRAY_SIZE(hmc5883_regval_to_nanoscale),
>> + },
>> + [HMC5883L_ID] = {
>> + .channels = hmc5883_channels,
>> + .regval_to_samp_freq = hmc5883_regval_to_samp_freq,
>> + .n_regval_to_samp_freq =
>> + ARRAY_SIZE(hmc5883_regval_to_samp_freq),
>> + .regval_to_nanoscale = hmc5883l_regval_to_nanoscale,
>> + .n_regval_to_nanoscale =
>> + ARRAY_SIZE(hmc5883l_regval_to_nanoscale),
>> + },
>> + [HMC5983_ID] = {
>> + .channels = hmc5983_channels,
>> + .regval_to_samp_freq = hmc5983_regval_to_samp_freq,
>> + .n_regval_to_samp_freq =
>> + ARRAY_SIZE(hmc5983_regval_to_samp_freq),
>> + .regval_to_nanoscale = hmc5883l_regval_to_nanoscale,
>> + .n_regval_to_nanoscale =
>> + ARRAY_SIZE(hmc5883l_regval_to_nanoscale),
>> + }
>> +};
>> +
>> +static int hmc5843_init(struct hmc5843_data *data)
>> +{
>> + int ret;
>> + u8 id[3];
>> +
>> + ret = regmap_bulk_read(data->regmap, HMC5843_ID_REG,
>> + id, ARRAY_SIZE(id));
>> + if (ret < 0)
>> + return ret;
>> + if (id[0] != 'H' || id[1] != '4' || id[2] != '3') {
>> + dev_err(data->dev, "no HMC5843/5883/5883L/5983 sensor\n");
>> + return -ENODEV;
>> + }
>> +
>> + ret = hmc5843_set_meas_conf(data, HMC5843_MEAS_CONF_NORMAL);
>> + if (ret < 0)
>> + return ret;
>> + ret = hmc5843_set_samp_freq(data, HMC5843_RATE_DEFAULT);
>> + if (ret < 0)
>> + return ret;
>> + ret = hmc5843_set_range_gain(data, HMC5843_RANGE_GAIN_DEFAULT);
>> + if (ret < 0)
>> + return ret;
>> + return hmc5843_set_mode(data, HMC5843_MODE_CONVERSION_CONTINUOUS);
>> +}
>> +
>> +static const struct iio_info hmc5843_info = {
>> + .attrs = &hmc5843_group,
>> + .read_raw = &hmc5843_read_raw,
>> + .write_raw = &hmc5843_write_raw,
>> + .write_raw_get_fmt = &hmc5843_write_raw_get_fmt,
>> + .driver_module = THIS_MODULE,
>> +};
>> +
>> +static const unsigned long hmc5843_scan_masks[] = {0x7, 0};
>> +
>> +int hmc5843_common_suspend(struct device *dev)
>> +{
>> + return hmc5843_set_mode(iio_priv(dev_get_drvdata(dev)),
>> + HMC5843_MODE_SLEEP);
>> +}
>> +EXPORT_SYMBOL(hmc5843_common_suspend);
>> +
>> +int hmc5843_common_resume(struct device *dev)
>> +{
>> + return hmc5843_set_mode(iio_priv(dev_get_drvdata(dev)),
>> + HMC5843_MODE_CONVERSION_CONTINUOUS);
>> +}
>> +EXPORT_SYMBOL(hmc5843_common_resume);
>> +
>> +int hmc5843_common_probe(struct device *dev, struct regmap *regmap,
>> + enum hmc5843_ids id, const char *name)
>> +{
>> + struct hmc5843_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);
>> +
>> + /* default settings at probe */
>> + data = iio_priv(indio_dev);
>> + data->dev = dev;
>> + data->regmap = regmap;
>> + data->variant = &hmc5843_chip_info_tbl[id];
>> + mutex_init(&data->lock);
>> +
>> + indio_dev->dev.parent = dev;
>> + indio_dev->name = name;
>> + indio_dev->info = &hmc5843_info;
>> + indio_dev->modes = INDIO_DIRECT_MODE;
>> + indio_dev->channels = data->variant->channels;
>> + indio_dev->num_channels = 4;
>> + indio_dev->available_scan_masks = hmc5843_scan_masks;
>> +
>> + ret = hmc5843_init(data);
>> + if (ret < 0)
>> + return ret;
>> +
>> + ret = iio_triggered_buffer_setup(indio_dev, NULL,
>> + hmc5843_trigger_handler, NULL);
>> + if (ret < 0)
>> + goto buffer_setup_err;
>> +
>> + ret = iio_device_register(indio_dev);
>> + if (ret < 0)
>> + goto buffer_cleanup;
>> +
>> + return 0;
>> +
>> +buffer_cleanup:
>> + iio_triggered_buffer_cleanup(indio_dev);
>> +buffer_setup_err:
>> + hmc5843_set_mode(iio_priv(indio_dev), HMC5843_MODE_SLEEP);
>> + return ret;
>> +}
>> +EXPORT_SYMBOL(hmc5843_common_probe);
>> +
>> +int hmc5843_common_remove(struct device *dev)
>> +{
>> + struct iio_dev *indio_dev = dev_get_drvdata(dev);
>> +
>> + iio_device_unregister(indio_dev);
>> + iio_triggered_buffer_cleanup(indio_dev);
>> +
>> + /* sleep mode to save power */
>> + hmc5843_set_mode(iio_priv(indio_dev), HMC5843_MODE_SLEEP);
>> +
>> + return 0;
>> +}
>> +EXPORT_SYMBOL(hmc5843_common_remove);
>> +
>> +MODULE_AUTHOR("Shubhrajyoti Datta <shubhrajyoti@xxxxxx>");
>> +MODULE_DESCRIPTION("HMC5843/5883/5883L/5983 core driver");
>> +MODULE_LICENSE("GPL");
>> diff --git a/drivers/iio/magnetometer/hmc5843_i2c.c b/drivers/iio/magnetometer/hmc5843_i2c.c
>> new file mode 100644
>> index 0000000..3de7f44
>> --- /dev/null
>> +++ b/drivers/iio/magnetometer/hmc5843_i2c.c
>> @@ -0,0 +1,103 @@
>> +/*
>> + * i2c driver for hmc5843/5843/5883/5883l/5983
>> + *
>> + * Split from hmc5843.c
>> + * Copyright (C) Josef Gajdusek <atx@xxxxxxxx>
>> + *
>> + * This program is free software; you can redistribute it and/or modify
>> + * it under the terms of the GNU General Public License version 2 as
>> + * published by the Free Software Foundation.
>> + */
>> +
>> +#include <linux/module.h>
>> +#include <linux/i2c.h>
>> +#include <linux/regmap.h>
>> +#include <linux/iio/iio.h>
>> +#include <linux/iio/triggered_buffer.h>
>> +
>> +#include "hmc5843.h"
>> +
>> +static const struct regmap_range hmc5843_readable_ranges[] = {
>> + regmap_reg_range(0, HMC5843_ID_END),
>> +};
>> +
>> +static const struct regmap_access_table hmc5843_readable_table = {
>> + .yes_ranges = hmc5843_readable_ranges,
>> + .n_yes_ranges = ARRAY_SIZE(hmc5843_readable_ranges),
>> +};
>> +
>> +static const struct regmap_range hmc5843_writable_ranges[] = {
>> + regmap_reg_range(0, HMC5843_MODE_REG),
>> +};
>> +
>> +static const struct regmap_access_table hmc5843_writable_table = {
>> + .yes_ranges = hmc5843_writable_ranges,
>> + .n_yes_ranges = ARRAY_SIZE(hmc5843_writable_ranges),
>> +};
>> +
>> +static const struct regmap_range hmc5843_volatile_ranges[] = {
>> + regmap_reg_range(HMC5843_DATA_OUT_MSB_REGS, HMC5843_STATUS_REG),
>> +};
>> +
>> +static const struct regmap_access_table hmc5843_volatile_table = {
>> + .yes_ranges = hmc5843_volatile_ranges,
>> + .n_yes_ranges = ARRAY_SIZE(hmc5843_volatile_ranges),
>> +};
>> +
>> +static const struct regmap_config hmc5843_i2c_regmap_config = {
>> + .reg_bits = 8,
>> + .val_bits = 8,
>> +
>> + .rd_table = &hmc5843_readable_table,
>> + .wr_table = &hmc5843_writable_table,
>> + .volatile_table = &hmc5843_volatile_table,
>> +
>> + .cache_type = REGCACHE_RBTREE,
>> +};
>> +
>> +static int hmc5843_i2c_probe(struct i2c_client *cli,
>> + const struct i2c_device_id *id)
>> +{
>> + return hmc5843_common_probe(&cli->dev,
>> + devm_regmap_init_i2c(cli, &hmc5843_i2c_regmap_config),
>> + id->driver_data, id->name);
>> +}
>> +
>> +static int hmc5843_i2c_remove(struct i2c_client *client)
>> +{
>> + return hmc5843_common_remove(&client->dev);
>> +}
>> +
>> +static const struct i2c_device_id hmc5843_id[] = {
>> + { "hmc5843", HMC5843_ID },
>> + { "hmc5883", HMC5883_ID },
>> + { "hmc5883l", HMC5883L_ID },
>> + { "hmc5983", HMC5983_ID },
>> + { }
>> +};
>> +MODULE_DEVICE_TABLE(i2c, hmc5843_id);
>> +
>> +static const struct of_device_id hmc5843_of_match[] = {
>> + { .compatible = "honeywell,hmc5843", .data = (void *)HMC5843_ID },
>> + { .compatible = "honeywell,hmc5883", .data = (void *)HMC5883_ID },
>> + { .compatible = "honeywell,hmc5883l", .data = (void *)HMC5883L_ID },
>> + { .compatible = "honeywell,hmc5983", .data = (void *)HMC5983_ID },
>> + {}
>> +};
>> +MODULE_DEVICE_TABLE(of, hmc5843_of_match);
>> +
>> +static struct i2c_driver hmc5843_driver = {
>> + .driver = {
>> + .name = "hmc5843",
>> + .pm = HMC5843_PM_OPS,
>> + .of_match_table = hmc5843_of_match,
>> + },
>> + .id_table = hmc5843_id,
>> + .probe = hmc5843_i2c_probe,
>> + .remove = hmc5843_i2c_remove,
>> +};
>> +module_i2c_driver(hmc5843_driver);
>> +
>> +MODULE_AUTHOR("Josef Gajdusek <atx@xxxxxxxx>");
>> +MODULE_DESCRIPTION("HMC5843/5883/5883L/5983 i2c driver");
>> +MODULE_LICENSE("GPL");
>> diff --git a/drivers/iio/magnetometer/hmc5843_spi.c b/drivers/iio/magnetometer/hmc5843_spi.c
>> new file mode 100644
>> index 0000000..535f03a
>> --- /dev/null
>> +++ b/drivers/iio/magnetometer/hmc5843_spi.c
>> @@ -0,0 +1,100 @@
>> +/*
>> + * SPI driver for hmc5983
>> + *
>> + * Copyright (C) Josef Gajdusek <atx@xxxxxxxx>
>> + *
>> + * This program is free software; you can redistribute it and/or modify
>> + * it under the terms of the GNU General Public License version 2 as
>> + * published by the Free Software Foundation.
>> + */
>> +
>> +#include <linux/module.h>
>> +#include <linux/spi/spi.h>
>> +#include <linux/iio/iio.h>
>> +
>> +#include "hmc5843.h"
>> +
>> +static const struct regmap_range hmc5843_readable_ranges[] = {
>> + regmap_reg_range(0, HMC5843_ID_END),
>> +};
>> +
>> +static const struct regmap_access_table hmc5843_readable_table = {
>> + .yes_ranges = hmc5843_readable_ranges,
>> + .n_yes_ranges = ARRAY_SIZE(hmc5843_readable_ranges),
>> +};
>> +
>> +static const struct regmap_range hmc5843_writable_ranges[] = {
>> + regmap_reg_range(0, HMC5843_MODE_REG),
>> +};
>> +
>> +static const struct regmap_access_table hmc5843_writable_table = {
>> + .yes_ranges = hmc5843_writable_ranges,
>> + .n_yes_ranges = ARRAY_SIZE(hmc5843_writable_ranges),
>> +};
>> +
>> +static const struct regmap_range hmc5843_volatile_ranges[] = {
>> + regmap_reg_range(HMC5843_DATA_OUT_MSB_REGS, HMC5843_STATUS_REG),
>> +};
>> +
>> +static const struct regmap_access_table hmc5843_volatile_table = {
>> + .yes_ranges = hmc5843_volatile_ranges,
>> + .n_yes_ranges = ARRAY_SIZE(hmc5843_volatile_ranges),
>> +};
>> +
>> +static const struct regmap_config hmc5843_spi_regmap_config = {
>> + .reg_bits = 8,
>> + .val_bits = 8,
>> +
>> + .rd_table = &hmc5843_readable_table,
>> + .wr_table = &hmc5843_writable_table,
>> + .volatile_table = &hmc5843_volatile_table,
>> +
>> + /* Autoincrement address pointer */
>> + .read_flag_mask = 0xc0,
>> +
>> + .cache_type = REGCACHE_RBTREE,
>> +};
>> +
>> +static int hmc5843_spi_probe(struct spi_device *spi)
>> +{
>> + int ret;
>> + const struct spi_device_id *id = spi_get_device_id(spi);
>> +
>> + spi->mode = SPI_MODE_3;
>> + spi->max_speed_hz = 8000000;
>> + spi->bits_per_word = 8;
>> + ret = spi_setup(spi);
>> + if (ret)
>> + return ret;
>> +
>> + return hmc5843_common_probe(&spi->dev,
>> + devm_regmap_init_spi(spi, &hmc5843_spi_regmap_config),
>> + id->driver_data, id->name);
>> +}
>> +
>> +static int hmc5843_spi_remove(struct spi_device *spi)
>> +{
>> + return hmc5843_common_remove(&spi->dev);
>> +}
>> +
>> +static const struct spi_device_id hmc5843_id[] = {
>> + { "hmc5983", HMC5983_ID },
>> + { }
>> +};
>> +MODULE_DEVICE_TABLE(spi, hmc5843_id);
>> +
>> +static struct spi_driver hmc5843_driver = {
>> + .driver = {
>> + .name = "hmc5843",
>> + .pm = HMC5843_PM_OPS,
>> + },
>> + .id_table = hmc5843_id,
>> + .probe = hmc5843_spi_probe,
>> + .remove = hmc5843_spi_remove,
>> +};
>> +
>> +module_spi_driver(hmc5843_driver);
>> +
>> +MODULE_AUTHOR("Josef Gajdusek <atx@xxxxxxxx>");
>> +MODULE_DESCRIPTION("HMC5983 SPI driver");
>> +MODULE_LICENSE("GPL");
>> diff --git a/drivers/staging/iio/magnetometer/Kconfig b/drivers/staging/iio/magnetometer/Kconfig
>> index dec814a..f2f1abd 100644
>> --- a/drivers/staging/iio/magnetometer/Kconfig
>> +++ b/drivers/staging/iio/magnetometer/Kconfig
>> @@ -3,38 +3,6 @@
>> #
>> menu "Magnetometer sensors"
>>
>> -config SENSORS_HMC5843
>> - tristate
>> - select IIO_BUFFER
>> - select IIO_TRIGGERED_BUFFER
>> -
>> -config SENSORS_HMC5843_I2C
>> - tristate "Honeywell HMC5843/5883/5883L 3-Axis Magnetometer (I2C)"
>> - depends on I2C
>> - select SENSORS_HMC5843
>> - select REGMAP_I2C
>> - help
>> - Say Y here to add support for the Honeywell HMC5843, HMC5883 and
>> - HMC5883L 3-Axis Magnetometer (digital compass).
>> -
>> - This driver can also be compiled as a set of modules.
>> - If so, these modules will be created:
>> - - hmc5843_core (core functions)
>> - - hmc5843_i2c (support for HMC5843, HMC5883, HMC5883L and HMC5983)
>> -
>> -config SENSORS_HMC5843_SPI
>> - tristate "Honeywell HMC5983 3-Axis Magnetometer (SPI)"
>> - depends on SPI_MASTER
>> - select SENSORS_HMC5843
>> - select REGMAP_SPI
>> - help
>> - Say Y here to add support for the Honeywell HMC5983 3-Axis Magnetometer
>> - (digital compass).
>> -
>> - This driver can also be compiled as a set of modules.
>> - If so, these modules will be created:
>> - - hmc5843_core (core functions)
>> - - hmc5843_spi (support for HMC5983)
>>
>>
>> endmenu
>> diff --git a/drivers/staging/iio/magnetometer/Makefile b/drivers/staging/iio/magnetometer/Makefile
>> index 33761a1..5e4a7e6 100644
>> --- a/drivers/staging/iio/magnetometer/Makefile
>> +++ b/drivers/staging/iio/magnetometer/Makefile
>> @@ -2,6 +2,4 @@
>> # Makefile for industrial I/O Magnetometer sensors
>> #
>>
>> -obj-$(CONFIG_SENSORS_HMC5843) += hmc5843_core.o
>> -obj-$(CONFIG_SENSORS_HMC5843_I2C) += hmc5843_i2c.o
>> -obj-$(CONFIG_SENSORS_HMC5843_SPI) += hmc5843_spi.o
>> +
>> diff --git a/drivers/staging/iio/magnetometer/hmc5843.h b/drivers/staging/iio/magnetometer/hmc5843.h
>> deleted file mode 100644
>> index 76a5d74..0000000
>> --- a/drivers/staging/iio/magnetometer/hmc5843.h
>> +++ /dev/null
>> @@ -1,65 +0,0 @@
>> -/*
>> - * Header file for hmc5843 driver
>> - *
>> - * Split from hmc5843.c
>> - * Copyright (C) Josef Gajdusek <atx@xxxxxxxx>
>> - *
>> - * This program is free software; you can redistribute it and/or modify
>> - * it under the terms of the GNU General Public License version 2 as
>> - * published by the Free Software Foundation.
>> - */
>> -
>> -#ifndef HMC5843_CORE_H
>> -#define HMC5843_CORE_H
>> -
>> -#include <linux/regmap.h>
>> -#include <linux/iio/iio.h>
>> -
>> -#define HMC5843_CONFIG_REG_A 0x00
>> -#define HMC5843_CONFIG_REG_B 0x01
>> -#define HMC5843_MODE_REG 0x02
>> -#define HMC5843_DATA_OUT_MSB_REGS 0x03
>> -#define HMC5843_STATUS_REG 0x09
>> -#define HMC5843_ID_REG 0x0a
>> -#define HMC5843_ID_END 0x0c
>> -
>> -enum hmc5843_ids {
>> - HMC5843_ID,
>> - HMC5883_ID,
>> - HMC5883L_ID,
>> - HMC5983_ID,
>> -};
>> -
>> -/**
>> - * struct hcm5843_data - device specific data
>> - * @dev: actual device
>> - * @lock: update and read regmap data
>> - * @regmap: hardware access register maps
>> - * @variant: describe chip variants
>> - * @buffer: 3x 16-bit channels + padding + 64-bit timestamp
>> - */
>> -struct hmc5843_data {
>> - struct device *dev;
>> - struct mutex lock;
>> - struct regmap *regmap;
>> - const struct hmc5843_chip_info *variant;
>> - __be16 buffer[8];
>> -};
>> -
>> -int hmc5843_common_probe(struct device *dev, struct regmap *regmap,
>> - enum hmc5843_ids id, const char *name);
>> -int hmc5843_common_remove(struct device *dev);
>> -
>> -int hmc5843_common_suspend(struct device *dev);
>> -int hmc5843_common_resume(struct device *dev);
>> -
>> -#ifdef CONFIG_PM_SLEEP
>> -static SIMPLE_DEV_PM_OPS(hmc5843_pm_ops,
>> - hmc5843_common_suspend,
>> - hmc5843_common_resume);
>> -#define HMC5843_PM_OPS (&hmc5843_pm_ops)
>> -#else
>> -#define HMC5843_PM_OPS NULL
>> -#endif
>> -
>> -#endif /* HMC5843_CORE_H */
>> diff --git a/drivers/staging/iio/magnetometer/hmc5843_core.c b/drivers/staging/iio/magnetometer/hmc5843_core.c
>> deleted file mode 100644
>> index 77882b4..0000000
>> --- a/drivers/staging/iio/magnetometer/hmc5843_core.c
>> +++ /dev/null
>> @@ -1,686 +0,0 @@
>> -/*
>> - * Device driver for the the HMC5843 multi-chip module designed
>> - * for low field magnetic sensing.
>> - *
>> - * Copyright (C) 2010 Texas Instruments
>> - *
>> - * Author: Shubhrajyoti Datta <shubhrajyoti@xxxxxx>
>> - * Acknowledgment: Jonathan Cameron <jic23@xxxxxxxxxx> for valuable inputs.
>> - * Support for HMC5883 and HMC5883L by Peter Meerwald <pmeerw@xxxxxxxxxx>.
>> - * Split to multiple files by Josef Gajdusek <atx@xxxxxxxx> - 2014
>> - *
>> - * This program is free software; you can redistribute it and/or modify
>> - * it under the terms of the GNU General Public License as published by
>> - * the Free Software Foundation; either version 2 of the License, or
>> - * (at your option) any later version.
>> - *
>> - * This program is distributed in the hope that it will be useful,
>> - * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
>> - * GNU General Public License for more details.
>> - */
>> -
>> -#include <linux/module.h>
>> -#include <linux/regmap.h>
>> -#include <linux/iio/iio.h>
>> -#include <linux/iio/sysfs.h>
>> -#include <linux/iio/trigger_consumer.h>
>> -#include <linux/iio/buffer.h>
>> -#include <linux/iio/triggered_buffer.h>
>> -#include <linux/delay.h>
>> -
>> -#include "hmc5843.h"
>> -
>> -/*
>> - * Range gain settings in (+-)Ga
>> - * Beware: HMC5843 and HMC5883 have different recommended sensor field
>> - * ranges; default corresponds to +-1.0 Ga and +-1.3 Ga, respectively
>> - */
>> -#define HMC5843_RANGE_GAIN_OFFSET 0x05
>> -#define HMC5843_RANGE_GAIN_DEFAULT 0x01
>> -#define HMC5843_RANGE_GAIN_MASK 0xe0
>> -
>> -/* Device status */
>> -#define HMC5843_DATA_READY 0x01
>> -#define HMC5843_DATA_OUTPUT_LOCK 0x02
>> -
>> -/* Mode register configuration */
>> -#define HMC5843_MODE_CONVERSION_CONTINUOUS 0x00
>> -#define HMC5843_MODE_CONVERSION_SINGLE 0x01
>> -#define HMC5843_MODE_IDLE 0x02
>> -#define HMC5843_MODE_SLEEP 0x03
>> -#define HMC5843_MODE_MASK 0x03
>> -
>> -/*
>> - * HMC5843: Minimum data output rate
>> - * HMC5883: Typical data output rate
>> - */
>> -#define HMC5843_RATE_OFFSET 0x02
>> -#define HMC5843_RATE_DEFAULT 0x04
>> -#define HMC5843_RATE_MASK 0x1c
>> -
>> -/* Device measurement configuration */
>> -#define HMC5843_MEAS_CONF_NORMAL 0x00
>> -#define HMC5843_MEAS_CONF_POSITIVE_BIAS 0x01
>> -#define HMC5843_MEAS_CONF_NEGATIVE_BIAS 0x02
>> -#define HMC5843_MEAS_CONF_MASK 0x03
>> -
>> -/*
>> - * API for setting the measurement configuration to
>> - * Normal, Positive bias and Negative bias
>> - *
>> - * From the datasheet:
>> - * 0 - Normal measurement configuration (default): In normal measurement
>> - * configuration the device follows normal measurement flow. Pins BP
>> - * and BN are left floating and high impedance.
>> - *
>> - * 1 - Positive bias configuration: In positive bias configuration, a
>> - * positive current is forced across the resistive load on pins BP
>> - * and BN.
>> - *
>> - * 2 - Negative bias configuration. In negative bias configuration, a
>> - * negative current is forced across the resistive load on pins BP
>> - * and BN.
>> - *
>> - * 3 - Only available on HMC5983. Magnetic sensor is disabled.
>> - * Temperature sensor is enabled.
>> - */
>> -
>> -static const char *const hmc5843_meas_conf_modes[] = {"normal", "positivebias",
>> - "negativebias"};
>> -
>> -static const char *const hmc5983_meas_conf_modes[] = {"normal", "positivebias",
>> - "negativebias",
>> - "disabled"};
>> -/* Scaling factors: 10000000/Gain */
>> -static const int hmc5843_regval_to_nanoscale[] = {
>> - 6173, 7692, 10309, 12821, 18868, 21739, 25641, 35714
>> -};
>> -
>> -static const int hmc5883_regval_to_nanoscale[] = {
>> - 7812, 9766, 13021, 16287, 24096, 27701, 32573, 45662
>> -};
>> -
>> -static const int hmc5883l_regval_to_nanoscale[] = {
>> - 7299, 9174, 12195, 15152, 22727, 25641, 30303, 43478
>> -};
>> -
>> -/*
>> - * From the datasheet:
>> - * Value | HMC5843 | HMC5883/HMC5883L
>> - * | Data output rate (Hz) | Data output rate (Hz)
>> - * 0 | 0.5 | 0.75
>> - * 1 | 1 | 1.5
>> - * 2 | 2 | 3
>> - * 3 | 5 | 7.5
>> - * 4 | 10 (default) | 15
>> - * 5 | 20 | 30
>> - * 6 | 50 | 75
>> - * 7 | Not used | Not used
>> - */
>> -static const int hmc5843_regval_to_samp_freq[][2] = {
>> - {0, 500000}, {1, 0}, {2, 0}, {5, 0}, {10, 0}, {20, 0}, {50, 0}
>> -};
>> -
>> -static const int hmc5883_regval_to_samp_freq[][2] = {
>> - {0, 750000}, {1, 500000}, {3, 0}, {7, 500000}, {15, 0}, {30, 0},
>> - {75, 0}
>> -};
>> -
>> -static const int hmc5983_regval_to_samp_freq[][2] = {
>> - {0, 750000}, {1, 500000}, {3, 0}, {7, 500000}, {15, 0}, {30, 0},
>> - {75, 0}, {220, 0}
>> -};
>> -
>> -/* Describe chip variants */
>> -struct hmc5843_chip_info {
>> - const struct iio_chan_spec *channels;
>> - const int (*regval_to_samp_freq)[2];
>> - const int n_regval_to_samp_freq;
>> - const int *regval_to_nanoscale;
>> - const int n_regval_to_nanoscale;
>> -};
>> -
>> -/* The lower two bits contain the current conversion mode */
>> -static s32 hmc5843_set_mode(struct hmc5843_data *data, u8 operating_mode)
>> -{
>> - int ret;
>> -
>> - mutex_lock(&data->lock);
>> - ret = regmap_update_bits(data->regmap, HMC5843_MODE_REG,
>> - HMC5843_MODE_MASK, operating_mode);
>> - mutex_unlock(&data->lock);
>> -
>> - return ret;
>> -}
>> -
>> -static int hmc5843_wait_measurement(struct hmc5843_data *data)
>> -{
>> - int tries = 150;
>> - unsigned int val;
>> - int ret;
>> -
>> - while (tries-- > 0) {
>> - ret = regmap_read(data->regmap, HMC5843_STATUS_REG, &val);
>> - if (ret < 0)
>> - return ret;
>> - if (val & HMC5843_DATA_READY)
>> - break;
>> - msleep(20);
>> - }
>> -
>> - if (tries < 0) {
>> - dev_err(data->dev, "data not ready\n");
>> - return -EIO;
>> - }
>> -
>> - return 0;
>> -}
>> -
>> -/* Return the measurement value from the specified channel */
>> -static int hmc5843_read_measurement(struct hmc5843_data *data,
>> - int idx, int *val)
>> -{
>> - __be16 values[3];
>> - int ret;
>> -
>> - mutex_lock(&data->lock);
>> - ret = hmc5843_wait_measurement(data);
>> - if (ret < 0) {
>> - mutex_unlock(&data->lock);
>> - return ret;
>> - }
>> - ret = regmap_bulk_read(data->regmap, HMC5843_DATA_OUT_MSB_REGS,
>> - values, sizeof(values));
>> - mutex_unlock(&data->lock);
>> - if (ret < 0)
>> - return ret;
>> -
>> - *val = sign_extend32(be16_to_cpu(values[idx]), 15);
>> - return IIO_VAL_INT;
>> -}
>> -
>> -static int hmc5843_set_meas_conf(struct hmc5843_data *data, u8 meas_conf)
>> -{
>> - int ret;
>> -
>> - mutex_lock(&data->lock);
>> - ret = regmap_update_bits(data->regmap, HMC5843_CONFIG_REG_A,
>> - HMC5843_MEAS_CONF_MASK, meas_conf);
>> - mutex_unlock(&data->lock);
>> -
>> - return ret;
>> -}
>> -
>> -static
>> -int hmc5843_show_measurement_configuration(struct iio_dev *indio_dev,
>> - const struct iio_chan_spec *chan)
>> -{
>> - struct hmc5843_data *data = iio_priv(indio_dev);
>> - unsigned int val;
>> - int ret;
>> -
>> - ret = regmap_read(data->regmap, HMC5843_CONFIG_REG_A, &val);
>> - if (ret)
>> - return ret;
>> -
>> - return val & HMC5843_MEAS_CONF_MASK;
>> -}
>> -
>> -static
>> -int hmc5843_set_measurement_configuration(struct iio_dev *indio_dev,
>> - const struct iio_chan_spec *chan,
>> - unsigned int meas_conf)
>> -{
>> - struct hmc5843_data *data = iio_priv(indio_dev);
>> -
>> - return hmc5843_set_meas_conf(data, meas_conf);
>> -}
>> -
>> -static const struct iio_enum hmc5843_meas_conf_enum = {
>> - .items = hmc5843_meas_conf_modes,
>> - .num_items = ARRAY_SIZE(hmc5843_meas_conf_modes),
>> - .get = hmc5843_show_measurement_configuration,
>> - .set = hmc5843_set_measurement_configuration,
>> -};
>> -
>> -static const struct iio_chan_spec_ext_info hmc5843_ext_info[] = {
>> - IIO_ENUM("meas_conf", true, &hmc5843_meas_conf_enum),
>> - IIO_ENUM_AVAILABLE("meas_conf", &hmc5843_meas_conf_enum),
>> - { },
>> -};
>> -
>> -static const struct iio_enum hmc5983_meas_conf_enum = {
>> - .items = hmc5983_meas_conf_modes,
>> - .num_items = ARRAY_SIZE(hmc5983_meas_conf_modes),
>> - .get = hmc5843_show_measurement_configuration,
>> - .set = hmc5843_set_measurement_configuration,
>> -};
>> -
>> -static const struct iio_chan_spec_ext_info hmc5983_ext_info[] = {
>> - IIO_ENUM("meas_conf", true, &hmc5983_meas_conf_enum),
>> - IIO_ENUM_AVAILABLE("meas_conf", &hmc5983_meas_conf_enum),
>> - { },
>> -};
>> -
>> -static
>> -ssize_t hmc5843_show_samp_freq_avail(struct device *dev,
>> - struct device_attribute *attr, char *buf)
>> -{
>> - struct hmc5843_data *data = iio_priv(dev_to_iio_dev(dev));
>> - size_t len = 0;
>> - int i;
>> -
>> - for (i = 0; i < data->variant->n_regval_to_samp_freq; i++)
>> - len += scnprintf(buf + len, PAGE_SIZE - len,
>> - "%d.%d ", data->variant->regval_to_samp_freq[i][0],
>> - data->variant->regval_to_samp_freq[i][1]);
>> -
>> - /* replace trailing space by newline */
>> - buf[len - 1] = '\n';
>> -
>> - return len;
>> -}
>> -
>> -static IIO_DEV_ATTR_SAMP_FREQ_AVAIL(hmc5843_show_samp_freq_avail);
>> -
>> -static int hmc5843_set_samp_freq(struct hmc5843_data *data, u8 rate)
>> -{
>> - int ret;
>> -
>> - mutex_lock(&data->lock);
>> - ret = regmap_update_bits(data->regmap, HMC5843_CONFIG_REG_A,
>> - HMC5843_RATE_MASK,
>> - rate << HMC5843_RATE_OFFSET);
>> - mutex_unlock(&data->lock);
>> -
>> - return ret;
>> -}
>> -
>> -static int hmc5843_get_samp_freq_index(struct hmc5843_data *data,
>> - int val, int val2)
>> -{
>> - int i;
>> -
>> - for (i = 0; i < data->variant->n_regval_to_samp_freq; i++)
>> - if (val == data->variant->regval_to_samp_freq[i][0] &&
>> - val2 == data->variant->regval_to_samp_freq[i][1])
>> - return i;
>> -
>> - return -EINVAL;
>> -}
>> -
>> -static int hmc5843_set_range_gain(struct hmc5843_data *data, u8 range)
>> -{
>> - int ret;
>> -
>> - mutex_lock(&data->lock);
>> - ret = regmap_update_bits(data->regmap, HMC5843_CONFIG_REG_B,
>> - HMC5843_RANGE_GAIN_MASK,
>> - range << HMC5843_RANGE_GAIN_OFFSET);
>> - mutex_unlock(&data->lock);
>> -
>> - return ret;
>> -}
>> -
>> -static ssize_t hmc5843_show_scale_avail(struct device *dev,
>> - struct device_attribute *attr,
>> - char *buf)
>> -{
>> - struct hmc5843_data *data = iio_priv(dev_to_iio_dev(dev));
>> -
>> - size_t len = 0;
>> - int i;
>> -
>> - for (i = 0; i < data->variant->n_regval_to_nanoscale; i++)
>> - len += scnprintf(buf + len, PAGE_SIZE - len,
>> - "0.%09d ", data->variant->regval_to_nanoscale[i]);
>> -
>> - /* replace trailing space by newline */
>> - buf[len - 1] = '\n';
>> -
>> - return len;
>> -}
>> -
>> -static IIO_DEVICE_ATTR(scale_available, S_IRUGO,
>> - hmc5843_show_scale_avail, NULL, 0);
>> -
>> -static int hmc5843_get_scale_index(struct hmc5843_data *data, int val, int val2)
>> -{
>> - int i;
>> -
>> - if (val)
>> - return -EINVAL;
>> -
>> - for (i = 0; i < data->variant->n_regval_to_nanoscale; i++)
>> - if (val2 == data->variant->regval_to_nanoscale[i])
>> - return i;
>> -
>> - return -EINVAL;
>> -}
>> -
>> -static int hmc5843_read_raw(struct iio_dev *indio_dev,
>> - struct iio_chan_spec const *chan,
>> - int *val, int *val2, long mask)
>> -{
>> - struct hmc5843_data *data = iio_priv(indio_dev);
>> - unsigned int rval;
>> - int ret;
>> -
>> - switch (mask) {
>> - case IIO_CHAN_INFO_RAW:
>> - return hmc5843_read_measurement(data, chan->scan_index, val);
>> - case IIO_CHAN_INFO_SCALE:
>> - ret = regmap_read(data->regmap, HMC5843_CONFIG_REG_B, &rval);
>> - if (ret < 0)
>> - return ret;
>> - rval >>= HMC5843_RANGE_GAIN_OFFSET;
>> - *val = 0;
>> - *val2 = data->variant->regval_to_nanoscale[rval];
>> - return IIO_VAL_INT_PLUS_NANO;
>> - case IIO_CHAN_INFO_SAMP_FREQ:
>> - ret = regmap_read(data->regmap, HMC5843_CONFIG_REG_A, &rval);
>> - if (ret < 0)
>> - return ret;
>> - rval >>= HMC5843_RATE_OFFSET;
>> - *val = data->variant->regval_to_samp_freq[rval][0];
>> - *val2 = data->variant->regval_to_samp_freq[rval][1];
>> - return IIO_VAL_INT_PLUS_MICRO;
>> - }
>> - return -EINVAL;
>> -}
>> -
>> -static int hmc5843_write_raw(struct iio_dev *indio_dev,
>> - struct iio_chan_spec const *chan,
>> - int val, int val2, long mask)
>> -{
>> - struct hmc5843_data *data = iio_priv(indio_dev);
>> - int rate, range;
>> -
>> - switch (mask) {
>> - case IIO_CHAN_INFO_SAMP_FREQ:
>> - rate = hmc5843_get_samp_freq_index(data, val, val2);
>> - if (rate < 0)
>> - return -EINVAL;
>> -
>> - return hmc5843_set_samp_freq(data, rate);
>> - case IIO_CHAN_INFO_SCALE:
>> - range = hmc5843_get_scale_index(data, val, val2);
>> - if (range < 0)
>> - return -EINVAL;
>> -
>> - return hmc5843_set_range_gain(data, range);
>> - default:
>> - return -EINVAL;
>> - }
>> -}
>> -
>> -static int hmc5843_write_raw_get_fmt(struct iio_dev *indio_dev,
>> - struct iio_chan_spec const *chan,
>> - long mask)
>> -{
>> - switch (mask) {
>> - case IIO_CHAN_INFO_SAMP_FREQ:
>> - return IIO_VAL_INT_PLUS_MICRO;
>> - case IIO_CHAN_INFO_SCALE:
>> - return IIO_VAL_INT_PLUS_NANO;
>> - default:
>> - return -EINVAL;
>> - }
>> -}
>> -
>> -static irqreturn_t hmc5843_trigger_handler(int irq, void *p)
>> -{
>> - struct iio_poll_func *pf = p;
>> - struct iio_dev *indio_dev = pf->indio_dev;
>> - struct hmc5843_data *data = iio_priv(indio_dev);
>> - int ret;
>> -
>> - mutex_lock(&data->lock);
>> - ret = hmc5843_wait_measurement(data);
>> - if (ret < 0) {
>> - mutex_unlock(&data->lock);
>> - goto done;
>> - }
>> -
>> - ret = regmap_bulk_read(data->regmap, HMC5843_DATA_OUT_MSB_REGS,
>> - data->buffer, 3 * sizeof(__be16));
>> -
>> - mutex_unlock(&data->lock);
>> - if (ret < 0)
>> - goto done;
>> -
>> - iio_push_to_buffers_with_timestamp(indio_dev, data->buffer,
>> - iio_get_time_ns());
>> -
>> -done:
>> - iio_trigger_notify_done(indio_dev->trig);
>> -
>> - return IRQ_HANDLED;
>> -}
>> -
>> -#define HMC5843_CHANNEL(axis, idx) \
>> - { \
>> - .type = IIO_MAGN, \
>> - .modified = 1, \
>> - .channel2 = IIO_MOD_##axis, \
>> - .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \
>> - .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) | \
>> - BIT(IIO_CHAN_INFO_SAMP_FREQ), \
>> - .scan_index = idx, \
>> - .scan_type = { \
>> - .sign = 's', \
>> - .realbits = 16, \
>> - .storagebits = 16, \
>> - .endianness = IIO_BE, \
>> - }, \
>> - .ext_info = hmc5843_ext_info, \
>> - }
>> -
>> -#define HMC5983_CHANNEL(axis, idx) \
>> - { \
>> - .type = IIO_MAGN, \
>> - .modified = 1, \
>> - .channel2 = IIO_MOD_##axis, \
>> - .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \
>> - .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) | \
>> - BIT(IIO_CHAN_INFO_SAMP_FREQ), \
>> - .scan_index = idx, \
>> - .scan_type = { \
>> - .sign = 's', \
>> - .realbits = 16, \
>> - .storagebits = 16, \
>> - .endianness = IIO_BE, \
>> - }, \
>> - .ext_info = hmc5983_ext_info, \
>> - }
>> -
>> -static const struct iio_chan_spec hmc5843_channels[] = {
>> - HMC5843_CHANNEL(X, 0),
>> - HMC5843_CHANNEL(Y, 1),
>> - HMC5843_CHANNEL(Z, 2),
>> - IIO_CHAN_SOFT_TIMESTAMP(3),
>> -};
>> -
>> -/* Beware: Y and Z are exchanged on HMC5883 and 5983 */
>> -static const struct iio_chan_spec hmc5883_channels[] = {
>> - HMC5843_CHANNEL(X, 0),
>> - HMC5843_CHANNEL(Z, 1),
>> - HMC5843_CHANNEL(Y, 2),
>> - IIO_CHAN_SOFT_TIMESTAMP(3),
>> -};
>> -
>> -static const struct iio_chan_spec hmc5983_channels[] = {
>> - HMC5983_CHANNEL(X, 0),
>> - HMC5983_CHANNEL(Z, 1),
>> - HMC5983_CHANNEL(Y, 2),
>> - IIO_CHAN_SOFT_TIMESTAMP(3),
>> -};
>> -
>> -static struct attribute *hmc5843_attributes[] = {
>> - &iio_dev_attr_scale_available.dev_attr.attr,
>> - &iio_dev_attr_sampling_frequency_available.dev_attr.attr,
>> - NULL
>> -};
>> -
>> -static const struct attribute_group hmc5843_group = {
>> - .attrs = hmc5843_attributes,
>> -};
>> -
>> -static const struct hmc5843_chip_info hmc5843_chip_info_tbl[] = {
>> - [HMC5843_ID] = {
>> - .channels = hmc5843_channels,
>> - .regval_to_samp_freq = hmc5843_regval_to_samp_freq,
>> - .n_regval_to_samp_freq =
>> - ARRAY_SIZE(hmc5843_regval_to_samp_freq),
>> - .regval_to_nanoscale = hmc5843_regval_to_nanoscale,
>> - .n_regval_to_nanoscale =
>> - ARRAY_SIZE(hmc5843_regval_to_nanoscale),
>> - },
>> - [HMC5883_ID] = {
>> - .channels = hmc5883_channels,
>> - .regval_to_samp_freq = hmc5883_regval_to_samp_freq,
>> - .n_regval_to_samp_freq =
>> - ARRAY_SIZE(hmc5883_regval_to_samp_freq),
>> - .regval_to_nanoscale = hmc5883_regval_to_nanoscale,
>> - .n_regval_to_nanoscale =
>> - ARRAY_SIZE(hmc5883_regval_to_nanoscale),
>> - },
>> - [HMC5883L_ID] = {
>> - .channels = hmc5883_channels,
>> - .regval_to_samp_freq = hmc5883_regval_to_samp_freq,
>> - .n_regval_to_samp_freq =
>> - ARRAY_SIZE(hmc5883_regval_to_samp_freq),
>> - .regval_to_nanoscale = hmc5883l_regval_to_nanoscale,
>> - .n_regval_to_nanoscale =
>> - ARRAY_SIZE(hmc5883l_regval_to_nanoscale),
>> - },
>> - [HMC5983_ID] = {
>> - .channels = hmc5983_channels,
>> - .regval_to_samp_freq = hmc5983_regval_to_samp_freq,
>> - .n_regval_to_samp_freq =
>> - ARRAY_SIZE(hmc5983_regval_to_samp_freq),
>> - .regval_to_nanoscale = hmc5883l_regval_to_nanoscale,
>> - .n_regval_to_nanoscale =
>> - ARRAY_SIZE(hmc5883l_regval_to_nanoscale),
>> - }
>> -};
>> -
>> -static int hmc5843_init(struct hmc5843_data *data)
>> -{
>> - int ret;
>> - u8 id[3];
>> -
>> - ret = regmap_bulk_read(data->regmap, HMC5843_ID_REG,
>> - id, ARRAY_SIZE(id));
>> - if (ret < 0)
>> - return ret;
>> - if (id[0] != 'H' || id[1] != '4' || id[2] != '3') {
>> - dev_err(data->dev, "no HMC5843/5883/5883L/5983 sensor\n");
>> - return -ENODEV;
>> - }
>> -
>> - ret = hmc5843_set_meas_conf(data, HMC5843_MEAS_CONF_NORMAL);
>> - if (ret < 0)
>> - return ret;
>> - ret = hmc5843_set_samp_freq(data, HMC5843_RATE_DEFAULT);
>> - if (ret < 0)
>> - return ret;
>> - ret = hmc5843_set_range_gain(data, HMC5843_RANGE_GAIN_DEFAULT);
>> - if (ret < 0)
>> - return ret;
>> - return hmc5843_set_mode(data, HMC5843_MODE_CONVERSION_CONTINUOUS);
>> -}
>> -
>> -static const struct iio_info hmc5843_info = {
>> - .attrs = &hmc5843_group,
>> - .read_raw = &hmc5843_read_raw,
>> - .write_raw = &hmc5843_write_raw,
>> - .write_raw_get_fmt = &hmc5843_write_raw_get_fmt,
>> - .driver_module = THIS_MODULE,
>> -};
>> -
>> -static const unsigned long hmc5843_scan_masks[] = {0x7, 0};
>> -
>> -int hmc5843_common_suspend(struct device *dev)
>> -{
>> - return hmc5843_set_mode(iio_priv(dev_get_drvdata(dev)),
>> - HMC5843_MODE_SLEEP);
>> -}
>> -EXPORT_SYMBOL(hmc5843_common_suspend);
>> -
>> -int hmc5843_common_resume(struct device *dev)
>> -{
>> - return hmc5843_set_mode(iio_priv(dev_get_drvdata(dev)),
>> - HMC5843_MODE_CONVERSION_CONTINUOUS);
>> -}
>> -EXPORT_SYMBOL(hmc5843_common_resume);
>> -
>> -int hmc5843_common_probe(struct device *dev, struct regmap *regmap,
>> - enum hmc5843_ids id, const char *name)
>> -{
>> - struct hmc5843_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);
>> -
>> - /* default settings at probe */
>> - data = iio_priv(indio_dev);
>> - data->dev = dev;
>> - data->regmap = regmap;
>> - data->variant = &hmc5843_chip_info_tbl[id];
>> - mutex_init(&data->lock);
>> -
>> - indio_dev->dev.parent = dev;
>> - indio_dev->name = name;
>> - indio_dev->info = &hmc5843_info;
>> - indio_dev->modes = INDIO_DIRECT_MODE;
>> - indio_dev->channels = data->variant->channels;
>> - indio_dev->num_channels = 4;
>> - indio_dev->available_scan_masks = hmc5843_scan_masks;
>> -
>> - ret = hmc5843_init(data);
>> - if (ret < 0)
>> - return ret;
>> -
>> - ret = iio_triggered_buffer_setup(indio_dev, NULL,
>> - hmc5843_trigger_handler, NULL);
>> - if (ret < 0)
>> - goto buffer_setup_err;
>> -
>> - ret = iio_device_register(indio_dev);
>> - if (ret < 0)
>> - goto buffer_cleanup;
>> -
>> - return 0;
>> -
>> -buffer_cleanup:
>> - iio_triggered_buffer_cleanup(indio_dev);
>> -buffer_setup_err:
>> - hmc5843_set_mode(iio_priv(indio_dev), HMC5843_MODE_SLEEP);
>> - return ret;
>> -}
>> -EXPORT_SYMBOL(hmc5843_common_probe);
>> -
>> -int hmc5843_common_remove(struct device *dev)
>> -{
>> - struct iio_dev *indio_dev = dev_get_drvdata(dev);
>> -
>> - iio_device_unregister(indio_dev);
>> - iio_triggered_buffer_cleanup(indio_dev);
>> -
>> - /* sleep mode to save power */
>> - hmc5843_set_mode(iio_priv(indio_dev), HMC5843_MODE_SLEEP);
>> -
>> - return 0;
>> -}
>> -EXPORT_SYMBOL(hmc5843_common_remove);
>> -
>> -MODULE_AUTHOR("Shubhrajyoti Datta <shubhrajyoti@xxxxxx>");
>> -MODULE_DESCRIPTION("HMC5843/5883/5883L/5983 core driver");
>> -MODULE_LICENSE("GPL");
>> diff --git a/drivers/staging/iio/magnetometer/hmc5843_i2c.c b/drivers/staging/iio/magnetometer/hmc5843_i2c.c
>> deleted file mode 100644
>> index 3de7f44..0000000
>> --- a/drivers/staging/iio/magnetometer/hmc5843_i2c.c
>> +++ /dev/null
>> @@ -1,103 +0,0 @@
>> -/*
>> - * i2c driver for hmc5843/5843/5883/5883l/5983
>> - *
>> - * Split from hmc5843.c
>> - * Copyright (C) Josef Gajdusek <atx@xxxxxxxx>
>> - *
>> - * This program is free software; you can redistribute it and/or modify
>> - * it under the terms of the GNU General Public License version 2 as
>> - * published by the Free Software Foundation.
>> - */
>> -
>> -#include <linux/module.h>
>> -#include <linux/i2c.h>
>> -#include <linux/regmap.h>
>> -#include <linux/iio/iio.h>
>> -#include <linux/iio/triggered_buffer.h>
>> -
>> -#include "hmc5843.h"
>> -
>> -static const struct regmap_range hmc5843_readable_ranges[] = {
>> - regmap_reg_range(0, HMC5843_ID_END),
>> -};
>> -
>> -static const struct regmap_access_table hmc5843_readable_table = {
>> - .yes_ranges = hmc5843_readable_ranges,
>> - .n_yes_ranges = ARRAY_SIZE(hmc5843_readable_ranges),
>> -};
>> -
>> -static const struct regmap_range hmc5843_writable_ranges[] = {
>> - regmap_reg_range(0, HMC5843_MODE_REG),
>> -};
>> -
>> -static const struct regmap_access_table hmc5843_writable_table = {
>> - .yes_ranges = hmc5843_writable_ranges,
>> - .n_yes_ranges = ARRAY_SIZE(hmc5843_writable_ranges),
>> -};
>> -
>> -static const struct regmap_range hmc5843_volatile_ranges[] = {
>> - regmap_reg_range(HMC5843_DATA_OUT_MSB_REGS, HMC5843_STATUS_REG),
>> -};
>> -
>> -static const struct regmap_access_table hmc5843_volatile_table = {
>> - .yes_ranges = hmc5843_volatile_ranges,
>> - .n_yes_ranges = ARRAY_SIZE(hmc5843_volatile_ranges),
>> -};
>> -
>> -static const struct regmap_config hmc5843_i2c_regmap_config = {
>> - .reg_bits = 8,
>> - .val_bits = 8,
>> -
>> - .rd_table = &hmc5843_readable_table,
>> - .wr_table = &hmc5843_writable_table,
>> - .volatile_table = &hmc5843_volatile_table,
>> -
>> - .cache_type = REGCACHE_RBTREE,
>> -};
>> -
>> -static int hmc5843_i2c_probe(struct i2c_client *cli,
>> - const struct i2c_device_id *id)
>> -{
>> - return hmc5843_common_probe(&cli->dev,
>> - devm_regmap_init_i2c(cli, &hmc5843_i2c_regmap_config),
>> - id->driver_data, id->name);
>> -}
>> -
>> -static int hmc5843_i2c_remove(struct i2c_client *client)
>> -{
>> - return hmc5843_common_remove(&client->dev);
>> -}
>> -
>> -static const struct i2c_device_id hmc5843_id[] = {
>> - { "hmc5843", HMC5843_ID },
>> - { "hmc5883", HMC5883_ID },
>> - { "hmc5883l", HMC5883L_ID },
>> - { "hmc5983", HMC5983_ID },
>> - { }
>> -};
>> -MODULE_DEVICE_TABLE(i2c, hmc5843_id);
>> -
>> -static const struct of_device_id hmc5843_of_match[] = {
>> - { .compatible = "honeywell,hmc5843", .data = (void *)HMC5843_ID },
>> - { .compatible = "honeywell,hmc5883", .data = (void *)HMC5883_ID },
>> - { .compatible = "honeywell,hmc5883l", .data = (void *)HMC5883L_ID },
>> - { .compatible = "honeywell,hmc5983", .data = (void *)HMC5983_ID },
>> - {}
>> -};
>> -MODULE_DEVICE_TABLE(of, hmc5843_of_match);
>> -
>> -static struct i2c_driver hmc5843_driver = {
>> - .driver = {
>> - .name = "hmc5843",
>> - .pm = HMC5843_PM_OPS,
>> - .of_match_table = hmc5843_of_match,
>> - },
>> - .id_table = hmc5843_id,
>> - .probe = hmc5843_i2c_probe,
>> - .remove = hmc5843_i2c_remove,
>> -};
>> -module_i2c_driver(hmc5843_driver);
>> -
>> -MODULE_AUTHOR("Josef Gajdusek <atx@xxxxxxxx>");
>> -MODULE_DESCRIPTION("HMC5843/5883/5883L/5983 i2c driver");
>> -MODULE_LICENSE("GPL");
>> diff --git a/drivers/staging/iio/magnetometer/hmc5843_spi.c b/drivers/staging/iio/magnetometer/hmc5843_spi.c
>> deleted file mode 100644
>> index 535f03a..0000000
>> --- a/drivers/staging/iio/magnetometer/hmc5843_spi.c
>> +++ /dev/null
>> @@ -1,100 +0,0 @@
>> -/*
>> - * SPI driver for hmc5983
>> - *
>> - * Copyright (C) Josef Gajdusek <atx@xxxxxxxx>
>> - *
>> - * This program is free software; you can redistribute it and/or modify
>> - * it under the terms of the GNU General Public License version 2 as
>> - * published by the Free Software Foundation.
>> - */
>> -
>> -#include <linux/module.h>
>> -#include <linux/spi/spi.h>
>> -#include <linux/iio/iio.h>
>> -
>> -#include "hmc5843.h"
>> -
>> -static const struct regmap_range hmc5843_readable_ranges[] = {
>> - regmap_reg_range(0, HMC5843_ID_END),
>> -};
>> -
>> -static const struct regmap_access_table hmc5843_readable_table = {
>> - .yes_ranges = hmc5843_readable_ranges,
>> - .n_yes_ranges = ARRAY_SIZE(hmc5843_readable_ranges),
>> -};
>> -
>> -static const struct regmap_range hmc5843_writable_ranges[] = {
>> - regmap_reg_range(0, HMC5843_MODE_REG),
>> -};
>> -
>> -static const struct regmap_access_table hmc5843_writable_table = {
>> - .yes_ranges = hmc5843_writable_ranges,
>> - .n_yes_ranges = ARRAY_SIZE(hmc5843_writable_ranges),
>> -};
>> -
>> -static const struct regmap_range hmc5843_volatile_ranges[] = {
>> - regmap_reg_range(HMC5843_DATA_OUT_MSB_REGS, HMC5843_STATUS_REG),
>> -};
>> -
>> -static const struct regmap_access_table hmc5843_volatile_table = {
>> - .yes_ranges = hmc5843_volatile_ranges,
>> - .n_yes_ranges = ARRAY_SIZE(hmc5843_volatile_ranges),
>> -};
>> -
>> -static const struct regmap_config hmc5843_spi_regmap_config = {
>> - .reg_bits = 8,
>> - .val_bits = 8,
>> -
>> - .rd_table = &hmc5843_readable_table,
>> - .wr_table = &hmc5843_writable_table,
>> - .volatile_table = &hmc5843_volatile_table,
>> -
>> - /* Autoincrement address pointer */
>> - .read_flag_mask = 0xc0,
>> -
>> - .cache_type = REGCACHE_RBTREE,
>> -};
>> -
>> -static int hmc5843_spi_probe(struct spi_device *spi)
>> -{
>> - int ret;
>> - const struct spi_device_id *id = spi_get_device_id(spi);
>> -
>> - spi->mode = SPI_MODE_3;
>> - spi->max_speed_hz = 8000000;
>> - spi->bits_per_word = 8;
>> - ret = spi_setup(spi);
>> - if (ret)
>> - return ret;
>> -
>> - return hmc5843_common_probe(&spi->dev,
>> - devm_regmap_init_spi(spi, &hmc5843_spi_regmap_config),
>> - id->driver_data, id->name);
>> -}
>> -
>> -static int hmc5843_spi_remove(struct spi_device *spi)
>> -{
>> - return hmc5843_common_remove(&spi->dev);
>> -}
>> -
>> -static const struct spi_device_id hmc5843_id[] = {
>> - { "hmc5983", HMC5983_ID },
>> - { }
>> -};
>> -MODULE_DEVICE_TABLE(spi, hmc5843_id);
>> -
>> -static struct spi_driver hmc5843_driver = {
>> - .driver = {
>> - .name = "hmc5843",
>> - .pm = HMC5843_PM_OPS,
>> - },
>> - .id_table = hmc5843_id,
>> - .probe = hmc5843_spi_probe,
>> - .remove = hmc5843_spi_remove,
>> -};
>> -
>> -module_spi_driver(hmc5843_driver);
>> -
>> -MODULE_AUTHOR("Josef Gajdusek <atx@xxxxxxxx>");
>> -MODULE_DESCRIPTION("HMC5983 SPI driver");
>> -MODULE_LICENSE("GPL");
>>
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-iio" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at http://vger.kernel.org/majordomo-info.html