diff options
Diffstat (limited to 'drivers/iio/inkern.c')
| -rw-r--r-- | drivers/iio/inkern.c | 40 | 
1 files changed, 36 insertions, 4 deletions
diff --git a/drivers/iio/inkern.c b/drivers/iio/inkern.c index 0cf5f8e06cf..c7497009d60 100644 --- a/drivers/iio/inkern.c +++ b/drivers/iio/inkern.c @@ -183,7 +183,7 @@ static struct iio_channel *of_iio_channel_get_by_name(struct device_node *np,  		else if (name && index >= 0) {  			pr_err("ERROR: could not get IIO channel %s:%s(%i)\n",  				np->full_name, name ? name : "", index); -			return chan; +			return NULL;  		}  		/* @@ -193,8 +193,9 @@ static struct iio_channel *of_iio_channel_get_by_name(struct device_node *np,  		 */  		np = np->parent;  		if (np && !of_get_property(np, "io-channel-ranges", NULL)) -			break; +			return NULL;  	} +  	return chan;  } @@ -317,6 +318,7 @@ struct iio_channel *iio_channel_get(struct device *dev,  		if (channel != NULL)  			return channel;  	} +  	return iio_channel_get_sys(name, channel_name);  }  EXPORT_SYMBOL_GPL(iio_channel_get); @@ -417,12 +419,24 @@ static int iio_channel_read(struct iio_channel *chan, int *val, int *val2,  	enum iio_chan_info_enum info)  {  	int unused; +	int vals[INDIO_MAX_RAW_ELEMENTS]; +	int ret; +	int val_len = 2;  	if (val2 == NULL)  		val2 = &unused; -	return chan->indio_dev->info->read_raw(chan->indio_dev, chan->channel, -						val, val2, info); +	if (chan->indio_dev->info->read_raw_multi) { +		ret = chan->indio_dev->info->read_raw_multi(chan->indio_dev, +					chan->channel, INDIO_MAX_RAW_ELEMENTS, +					vals, &val_len, info); +		*val = vals[0]; +		*val2 = vals[1]; +	} else +		ret = chan->indio_dev->info->read_raw(chan->indio_dev, +					chan->channel, val, val2, info); + +	return ret;  }  int iio_read_channel_raw(struct iio_channel *chan, int *val) @@ -443,6 +457,24 @@ err_unlock:  }  EXPORT_SYMBOL_GPL(iio_read_channel_raw); +int iio_read_channel_average_raw(struct iio_channel *chan, int *val) +{ +	int ret; + +	mutex_lock(&chan->indio_dev->info_exist_lock); +	if (chan->indio_dev->info == NULL) { +		ret = -ENODEV; +		goto err_unlock; +	} + +	ret = iio_channel_read(chan, val, NULL, IIO_CHAN_INFO_AVERAGE_RAW); +err_unlock: +	mutex_unlock(&chan->indio_dev->info_exist_lock); + +	return ret; +} +EXPORT_SYMBOL_GPL(iio_read_channel_average_raw); +  static int iio_convert_raw_to_processed_unlocked(struct iio_channel *chan,  	int raw, int *processed, unsigned int scale)  {  | 
