Skip to content

Commit

Permalink
iio: Update iio_channel_get_all and iio_channel_get_all_cb API
Browse files Browse the repository at this point in the history
Pass device pointer instead of device name as parameter to iio_channel_get_all
and iio_channel_get_all_cb. This will enable us to use OF information to
retrieve consumer channel information.

Signed-off-by: Guenter Roeck <[email protected]>
Signed-off-by: Jonathan Cameron <[email protected]>
  • Loading branch information
groeck authored and jic23 committed Feb 2, 2013
1 parent 482bb4e commit ca7d98d
Show file tree
Hide file tree
Showing 4 changed files with 17 additions and 11 deletions.
4 changes: 2 additions & 2 deletions drivers/iio/buffer_cb.c
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ static struct iio_buffer_access_funcs iio_cb_access = {
.store_to = &iio_buffer_cb_store_to,
};

struct iio_cb_buffer *iio_channel_get_all_cb(const char *name,
struct iio_cb_buffer *iio_channel_get_all_cb(struct device *dev,
int (*cb)(u8 *data,
void *private),
void *private)
Expand All @@ -46,7 +46,7 @@ struct iio_cb_buffer *iio_channel_get_all_cb(const char *name,
cb_buff->buffer.access = &iio_cb_access;
INIT_LIST_HEAD(&cb_buff->buffer.demux_list);

cb_buff->channels = iio_channel_get_all(name);
cb_buff->channels = iio_channel_get_all(dev);
if (IS_ERR(cb_buff->channels)) {
ret = PTR_ERR(cb_buff->channels);
goto error_free_cb_buff;
Expand Down
6 changes: 4 additions & 2 deletions drivers/iio/inkern.c
Original file line number Diff line number Diff line change
Expand Up @@ -167,16 +167,18 @@ void iio_channel_release(struct iio_channel *channel)
}
EXPORT_SYMBOL_GPL(iio_channel_release);

struct iio_channel *iio_channel_get_all(const char *name)
struct iio_channel *iio_channel_get_all(struct device *dev)
{
const char *name;
struct iio_channel *chans;
struct iio_map_internal *c = NULL;
int nummaps = 0;
int mapind = 0;
int i, ret;

if (name == NULL)
if (dev == NULL)
return ERR_PTR(-EINVAL);
name = dev_name(dev);

mutex_lock(&iio_map_list_lock);
/* first count the matching maps */
Expand Down
9 changes: 6 additions & 3 deletions drivers/staging/iio/iio_hwmon.c
Original file line number Diff line number Diff line change
Expand Up @@ -71,14 +71,17 @@ static int iio_hwmon_probe(struct platform_device *pdev)
int ret, i;
int in_i = 1, temp_i = 1, curr_i = 1;
enum iio_chan_type type;
struct iio_channel *channels;

channels = iio_channel_get_all(dev);
if (IS_ERR(channels))
return PTR_ERR(channels);

st = devm_kzalloc(dev, sizeof(*st), GFP_KERNEL);
if (st == NULL)
return -ENOMEM;

st->channels = iio_channel_get_all(dev_name(dev));
if (IS_ERR(st->channels))
return PTR_ERR(st->channels);
st->channels = channels;

/* count how many attributes we have */
while (st->channels[st->num_channels].indio_dev)
Expand Down
9 changes: 5 additions & 4 deletions include/linux/iio/consumer.h
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@

struct iio_dev;
struct iio_chan_spec;
struct device;

/**
* struct iio_channel - everything needed for a consumer to use a channel
Expand Down Expand Up @@ -48,14 +49,14 @@ void iio_channel_release(struct iio_channel *chan);

/**
* iio_channel_get_all() - get all channels associated with a client
* @name: name of consumer device.
* @dev: Pointer to consumer device.
*
* Returns an array of iio_channel structures terminated with one with
* null iio_dev pointer.
* This function is used by fairly generic consumers to get all the
* channels registered as having this consumer.
*/
struct iio_channel *iio_channel_get_all(const char *name);
struct iio_channel *iio_channel_get_all(struct device *dev);

/**
* iio_channel_release_all() - reverse iio_channel_get_all
Expand All @@ -66,15 +67,15 @@ void iio_channel_release_all(struct iio_channel *chan);
struct iio_cb_buffer;
/**
* iio_channel_get_all_cb() - register callback for triggered capture
* @name: Name of client device.
* @dev: Pointer to client device.
* @cb: Callback function.
* @private: Private data passed to callback.
*
* NB right now we have no ability to mux data from multiple devices.
* So if the channels requested come from different devices this will
* fail.
*/
struct iio_cb_buffer *iio_channel_get_all_cb(const char *name,
struct iio_cb_buffer *iio_channel_get_all_cb(struct device *dev,
int (*cb)(u8 *data,
void *private),
void *private);
Expand Down

0 comments on commit ca7d98d

Please sign in to comment.