staging:iio:magnetometer:ak8975: remove 'mode' attribute
The raw data reading process (ak8975_read_axis) sets the single measurement mode to take a sample and once the conversion is completed the device enters into power-down mode automatically, therefore there is no need to enable a flag for this to happen. Signed-off-by: Leed Aguilar <leed.aguilar@ti.com> Acked-by: Jonathan Cameron <jic23@kernel.org> Acked-by: Laxman Dewangan <ldewangan@nvidia.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
82f2acdce1
commit
4bf8523df9
|
@ -92,7 +92,6 @@ struct ak8975_data {
|
||||||
struct mutex lock;
|
struct mutex lock;
|
||||||
u8 asa[3];
|
u8 asa[3];
|
||||||
long raw_to_gauss[3];
|
long raw_to_gauss[3];
|
||||||
bool mode;
|
|
||||||
u8 reg_cache[AK8975_MAX_REGS];
|
u8 reg_cache[AK8975_MAX_REGS];
|
||||||
int eoc_gpio;
|
int eoc_gpio;
|
||||||
int eoc_irq;
|
int eoc_irq;
|
||||||
|
@ -247,60 +246,6 @@ static int ak8975_setup(struct i2c_client *client)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Shows the device's mode. 0 = off, 1 = on.
|
|
||||||
*/
|
|
||||||
static ssize_t show_mode(struct device *dev, struct device_attribute *devattr,
|
|
||||||
char *buf)
|
|
||||||
{
|
|
||||||
struct iio_dev *indio_dev = dev_to_iio_dev(dev);
|
|
||||||
struct ak8975_data *data = iio_priv(indio_dev);
|
|
||||||
|
|
||||||
return sprintf(buf, "%u\n", data->mode);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Sets the device's mode. 0 = off, 1 = on. The device's mode must be on
|
|
||||||
* for the magn raw attributes to be available.
|
|
||||||
*/
|
|
||||||
static ssize_t store_mode(struct device *dev, struct device_attribute *devattr,
|
|
||||||
const char *buf, size_t count)
|
|
||||||
{
|
|
||||||
struct iio_dev *indio_dev = dev_to_iio_dev(dev);
|
|
||||||
struct ak8975_data *data = iio_priv(indio_dev);
|
|
||||||
struct i2c_client *client = data->client;
|
|
||||||
bool value;
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
/* Convert mode string and do some basic sanity checking on it.
|
|
||||||
only 0 or 1 are valid. */
|
|
||||||
ret = strtobool(buf, &value);
|
|
||||||
if (ret < 0)
|
|
||||||
return ret;
|
|
||||||
|
|
||||||
mutex_lock(&data->lock);
|
|
||||||
|
|
||||||
/* Write the mode to the device. */
|
|
||||||
if (data->mode != value) {
|
|
||||||
ret = ak8975_write_data(client,
|
|
||||||
AK8975_REG_CNTL,
|
|
||||||
(u8)value,
|
|
||||||
AK8975_REG_CNTL_MODE_MASK,
|
|
||||||
AK8975_REG_CNTL_MODE_SHIFT);
|
|
||||||
|
|
||||||
if (ret < 0) {
|
|
||||||
dev_err(&client->dev, "Error in setting mode\n");
|
|
||||||
mutex_unlock(&data->lock);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
data->mode = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
mutex_unlock(&data->lock);
|
|
||||||
|
|
||||||
return count;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int wait_conversion_complete_gpio(struct ak8975_data *data)
|
static int wait_conversion_complete_gpio(struct ak8975_data *data)
|
||||||
{
|
{
|
||||||
struct i2c_client *client = data->client;
|
struct i2c_client *client = data->client;
|
||||||
|
@ -368,12 +313,6 @@ static int ak8975_read_axis(struct iio_dev *indio_dev, int index, int *val)
|
||||||
|
|
||||||
mutex_lock(&data->lock);
|
mutex_lock(&data->lock);
|
||||||
|
|
||||||
if (data->mode == 0) {
|
|
||||||
dev_err(&client->dev, "Operating mode is in power down mode\n");
|
|
||||||
ret = -EBUSY;
|
|
||||||
goto exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Set up the device for taking a sample. */
|
/* Set up the device for taking a sample. */
|
||||||
ret = ak8975_write_data(client,
|
ret = ak8975_write_data(client,
|
||||||
AK8975_REG_CNTL,
|
AK8975_REG_CNTL,
|
||||||
|
@ -465,19 +404,7 @@ static const struct iio_chan_spec ak8975_channels[] = {
|
||||||
AK8975_CHANNEL(X, 0), AK8975_CHANNEL(Y, 1), AK8975_CHANNEL(Z, 2),
|
AK8975_CHANNEL(X, 0), AK8975_CHANNEL(Y, 1), AK8975_CHANNEL(Z, 2),
|
||||||
};
|
};
|
||||||
|
|
||||||
static IIO_DEVICE_ATTR(mode, S_IRUGO | S_IWUSR, show_mode, store_mode, 0);
|
|
||||||
|
|
||||||
static struct attribute *ak8975_attr[] = {
|
|
||||||
&iio_dev_attr_mode.dev_attr.attr,
|
|
||||||
NULL
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct attribute_group ak8975_attr_group = {
|
|
||||||
.attrs = ak8975_attr,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct iio_info ak8975_info = {
|
static const struct iio_info ak8975_info = {
|
||||||
.attrs = &ak8975_attr_group,
|
|
||||||
.read_raw = &ak8975_read_raw,
|
.read_raw = &ak8975_read_raw,
|
||||||
.driver_module = THIS_MODULE,
|
.driver_module = THIS_MODULE,
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue