Add new sr_dev_config_capabilities() helper function.
This commit is contained in:
parent
12f2f640cb
commit
71e9c54dab
|
@ -56,6 +56,8 @@ SR_API int sr_dev_channel_name_set(struct sr_channel *channel,
|
||||||
SR_API int sr_dev_channel_enable(struct sr_channel *channel,
|
SR_API int sr_dev_channel_enable(struct sr_channel *channel,
|
||||||
gboolean state);
|
gboolean state);
|
||||||
SR_API gboolean sr_dev_has_option(const struct sr_dev_inst *sdi, int key);
|
SR_API gboolean sr_dev_has_option(const struct sr_dev_inst *sdi, int key);
|
||||||
|
SR_API int sr_dev_config_capabilities(const struct sr_dev_inst *sdi,
|
||||||
|
const struct sr_channel_group *cg, int key);
|
||||||
SR_API GSList *sr_dev_list(const struct sr_dev_driver *driver);
|
SR_API GSList *sr_dev_list(const struct sr_dev_driver *driver);
|
||||||
SR_API int sr_dev_clear(const struct sr_dev_driver *driver);
|
SR_API int sr_dev_clear(const struct sr_dev_driver *driver);
|
||||||
SR_API int sr_dev_open(struct sr_dev_inst *sdi);
|
SR_API int sr_dev_open(struct sr_dev_inst *sdi);
|
||||||
|
|
46
src/device.c
46
src/device.c
|
@ -196,6 +196,52 @@ SR_API gboolean sr_dev_has_option(const struct sr_dev_inst *sdi, int key)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enumerate the configuration capabilities supported by a device instance
|
||||||
|
* for a given configuration key.
|
||||||
|
*
|
||||||
|
* @param sdi Pointer to the device instance to be checked. Must not be NULL.
|
||||||
|
* If the device's 'driver' field is NULL (virtual device), this
|
||||||
|
* function will always return FALSE (virtual devices don't have
|
||||||
|
* a hardware capabilities list).
|
||||||
|
* @param cg Pointer to a channel group, if a specific channel group is to
|
||||||
|
* be checked. Must be NULL to check device-wide options.
|
||||||
|
* @param[in] key The option that should be checked for is supported by the
|
||||||
|
* specified device.
|
||||||
|
*
|
||||||
|
* @retval A bitmask of enum sr_configcap values, which will be zero for
|
||||||
|
* invalid inputs or if the key is unsupported.
|
||||||
|
*
|
||||||
|
* @since 0.4.0
|
||||||
|
*/
|
||||||
|
SR_API int sr_dev_config_capabilities(const struct sr_dev_inst *sdi,
|
||||||
|
const struct sr_channel_group *cg, const int key)
|
||||||
|
{
|
||||||
|
GVariant *gvar;
|
||||||
|
const int *devopts;
|
||||||
|
gsize num_opts, i;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (!sdi || !sdi->driver || !sdi->driver->config_list)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (sdi->driver->config_list(SR_CONF_DEVICE_OPTIONS,
|
||||||
|
&gvar, sdi, cg) != SR_OK)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
ret = 0;
|
||||||
|
devopts = g_variant_get_fixed_array(gvar, &num_opts, sizeof(int32_t));
|
||||||
|
for (i = 0; i < num_opts; i++) {
|
||||||
|
if ((devopts[i] & SR_CONF_MASK) == key) {
|
||||||
|
ret = devopts[i] & ~SR_CONF_MASK;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_variant_unref(gvar);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocate and init a new user-generated device instance.
|
* Allocate and init a new user-generated device instance.
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in New Issue