iio: Allow to read mount matrix from ACPI
Currently mount matrix is allowed in Device Tree, though there is no technical issue to extend it to support ACPI. Convert the function to use device_property_read_string_array() and thus allow to read mount matrix from ACPI if available. Example of use in _DSD method: Name (_DSD, Package () { ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"), Package () { Package () { "mount-matrix", Package() { "1", "0", "0", "0", "0.866", "0.5", "0", "-0.5", "0.866", } }, } }) At the same time drop the "of" prefix from its name and convert current users. No functional change intended. Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Reviewed-by: Linus Walleij <linus.walleij@linaro.org> Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
This commit is contained in:
parent
0a39ac29e0
commit
fb1589710e
|
@ -420,9 +420,7 @@ int kxsd9_common_probe(struct device *dev,
|
||||||
indio_dev->available_scan_masks = kxsd9_scan_masks;
|
indio_dev->available_scan_masks = kxsd9_scan_masks;
|
||||||
|
|
||||||
/* Read the mounting matrix, if present */
|
/* Read the mounting matrix, if present */
|
||||||
ret = of_iio_read_mount_matrix(dev,
|
ret = iio_read_mount_matrix(dev, "mount-matrix", &st->orientation);
|
||||||
"mount-matrix",
|
|
||||||
&st->orientation);
|
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
|
|
@ -1149,8 +1149,7 @@ int mpu3050_common_probe(struct device *dev,
|
||||||
mpu3050->divisor = 99;
|
mpu3050->divisor = 99;
|
||||||
|
|
||||||
/* Read the mounting matrix, if present */
|
/* Read the mounting matrix, if present */
|
||||||
ret = of_iio_read_mount_matrix(dev, "mount-matrix",
|
ret = iio_read_mount_matrix(dev, "mount-matrix", &mpu3050->orientation);
|
||||||
&mpu3050->orientation);
|
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
|
|
@ -1021,8 +1021,8 @@ int inv_mpu_core_probe(struct regmap *regmap, int irq, const char *name,
|
||||||
|
|
||||||
pdata = dev_get_platdata(dev);
|
pdata = dev_get_platdata(dev);
|
||||||
if (!pdata) {
|
if (!pdata) {
|
||||||
result = of_iio_read_mount_matrix(dev, "mount-matrix",
|
result = iio_read_mount_matrix(dev, "mount-matrix",
|
||||||
&st->orientation);
|
&st->orientation);
|
||||||
if (result) {
|
if (result) {
|
||||||
dev_err(dev, "Failed to retrieve mounting matrix %d\n",
|
dev_err(dev, "Failed to retrieve mounting matrix %d\n",
|
||||||
result);
|
result);
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include <linux/device.h>
|
#include <linux/device.h>
|
||||||
#include <linux/fs.h>
|
#include <linux/fs.h>
|
||||||
#include <linux/poll.h>
|
#include <linux/poll.h>
|
||||||
|
#include <linux/property.h>
|
||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
#include <linux/wait.h>
|
#include <linux/wait.h>
|
||||||
#include <linux/cdev.h>
|
#include <linux/cdev.h>
|
||||||
|
@ -530,8 +531,8 @@ ssize_t iio_show_mount_matrix(struct iio_dev *indio_dev, uintptr_t priv,
|
||||||
EXPORT_SYMBOL_GPL(iio_show_mount_matrix);
|
EXPORT_SYMBOL_GPL(iio_show_mount_matrix);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* of_iio_read_mount_matrix() - retrieve iio device mounting matrix from
|
* iio_read_mount_matrix() - retrieve iio device mounting matrix from
|
||||||
* device-tree "mount-matrix" property
|
* device "mount-matrix" property
|
||||||
* @dev: device the mounting matrix property is assigned to
|
* @dev: device the mounting matrix property is assigned to
|
||||||
* @propname: device specific mounting matrix property name
|
* @propname: device specific mounting matrix property name
|
||||||
* @matrix: where to store retrieved matrix
|
* @matrix: where to store retrieved matrix
|
||||||
|
@ -541,40 +542,29 @@ EXPORT_SYMBOL_GPL(iio_show_mount_matrix);
|
||||||
*
|
*
|
||||||
* Return: 0 if success, or a negative error code on failure.
|
* Return: 0 if success, or a negative error code on failure.
|
||||||
*/
|
*/
|
||||||
#ifdef CONFIG_OF
|
int iio_read_mount_matrix(struct device *dev, const char *propname,
|
||||||
int of_iio_read_mount_matrix(const struct device *dev,
|
struct iio_mount_matrix *matrix)
|
||||||
const char *propname,
|
|
||||||
struct iio_mount_matrix *matrix)
|
|
||||||
{
|
{
|
||||||
if (dev->of_node) {
|
size_t len = ARRAY_SIZE(iio_mount_idmatrix.rotation);
|
||||||
int err = of_property_read_string_array(dev->of_node,
|
int err;
|
||||||
propname, matrix->rotation,
|
|
||||||
ARRAY_SIZE(iio_mount_idmatrix.rotation));
|
|
||||||
|
|
||||||
if (err == ARRAY_SIZE(iio_mount_idmatrix.rotation))
|
err = device_property_read_string_array(dev, propname,
|
||||||
return 0;
|
matrix->rotation, len);
|
||||||
|
if (err == len)
|
||||||
|
return 0;
|
||||||
|
|
||||||
if (err >= 0)
|
if (err >= 0)
|
||||||
/* Invalid number of matrix entries. */
|
/* Invalid number of matrix entries. */
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
if (err != -EINVAL)
|
if (err != -EINVAL)
|
||||||
/* Invalid matrix declaration format. */
|
/* Invalid matrix declaration format. */
|
||||||
return err;
|
return err;
|
||||||
}
|
|
||||||
|
|
||||||
/* Matrix was not declared at all: fallback to identity. */
|
/* Matrix was not declared at all: fallback to identity. */
|
||||||
return iio_setup_mount_idmatrix(dev, matrix);
|
return iio_setup_mount_idmatrix(dev, matrix);
|
||||||
}
|
}
|
||||||
#else
|
EXPORT_SYMBOL(iio_read_mount_matrix);
|
||||||
int of_iio_read_mount_matrix(const struct device *dev,
|
|
||||||
const char *propname,
|
|
||||||
struct iio_mount_matrix *matrix)
|
|
||||||
{
|
|
||||||
return iio_setup_mount_idmatrix(dev, matrix);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
EXPORT_SYMBOL(of_iio_read_mount_matrix);
|
|
||||||
|
|
||||||
static ssize_t __iio_format_value(char *buf, size_t len, unsigned int type,
|
static ssize_t __iio_format_value(char *buf, size_t len, unsigned int type,
|
||||||
int size, const int *vals)
|
int size, const int *vals)
|
||||||
|
|
|
@ -733,9 +733,8 @@ static int ak8974_probe(struct i2c_client *i2c,
|
||||||
ak8974->i2c = i2c;
|
ak8974->i2c = i2c;
|
||||||
mutex_init(&ak8974->lock);
|
mutex_init(&ak8974->lock);
|
||||||
|
|
||||||
ret = of_iio_read_mount_matrix(&i2c->dev,
|
ret = iio_read_mount_matrix(&i2c->dev, "mount-matrix",
|
||||||
"mount-matrix",
|
&ak8974->orientation);
|
||||||
&ak8974->orientation);
|
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
|
|
@ -911,9 +911,8 @@ static int ak8975_probe(struct i2c_client *client,
|
||||||
data->eoc_irq = 0;
|
data->eoc_irq = 0;
|
||||||
|
|
||||||
if (!pdata) {
|
if (!pdata) {
|
||||||
err = of_iio_read_mount_matrix(&client->dev,
|
err = iio_read_mount_matrix(&client->dev, "mount-matrix",
|
||||||
"mount-matrix",
|
&data->orientation);
|
||||||
&data->orientation);
|
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
} else
|
} else
|
||||||
|
|
|
@ -130,8 +130,8 @@ struct iio_mount_matrix {
|
||||||
|
|
||||||
ssize_t iio_show_mount_matrix(struct iio_dev *indio_dev, uintptr_t priv,
|
ssize_t iio_show_mount_matrix(struct iio_dev *indio_dev, uintptr_t priv,
|
||||||
const struct iio_chan_spec *chan, char *buf);
|
const struct iio_chan_spec *chan, char *buf);
|
||||||
int of_iio_read_mount_matrix(const struct device *dev, const char *propname,
|
int iio_read_mount_matrix(struct device *dev, const char *propname,
|
||||||
struct iio_mount_matrix *matrix);
|
struct iio_mount_matrix *matrix);
|
||||||
|
|
||||||
typedef const struct iio_mount_matrix *
|
typedef const struct iio_mount_matrix *
|
||||||
(iio_get_mount_matrix_t)(const struct iio_dev *indio_dev,
|
(iio_get_mount_matrix_t)(const struct iio_dev *indio_dev,
|
||||||
|
|
Loading…
Reference in New Issue