|
@@ -92,7 +92,6 @@ struct ak8975_data {
|
|
|
struct mutex lock;
|
|
|
u8 asa[3];
|
|
|
long raw_to_gauss[3];
|
|
|
- bool mode;
|
|
|
u8 reg_cache[AK8975_MAX_REGS];
|
|
|
int eoc_gpio;
|
|
|
int eoc_irq;
|
|
@@ -247,60 +246,6 @@ static int ak8975_setup(struct i2c_client *client)
|
|
|
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)
|
|
|
{
|
|
|
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);
|
|
|
|
|
|
- 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. */
|
|
|
ret = ak8975_write_data(client,
|
|
|
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),
|
|
|
};
|
|
|
|
|
|
-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 = {
|
|
|
- .attrs = &ak8975_attr_group,
|
|
|
.read_raw = &ak8975_read_raw,
|
|
|
.driver_module = THIS_MODULE,
|
|
|
};
|