genericdmm: device scan fixes
This commit is contained in:
parent
f1a14ea7ab
commit
d6db79a48c
|
@ -150,7 +150,7 @@ static GSList *connect_usb(const char *conn)
|
||||||
|
|
||||||
devcnt = g_slist_length(gdi->instances);
|
devcnt = g_slist_length(gdi->instances);
|
||||||
if (!(sdi = sr_dev_inst_new(devcnt, SR_ST_ACTIVE,
|
if (!(sdi = sr_dev_inst_new(devcnt, SR_ST_ACTIVE,
|
||||||
"Generic DMM", NULL, NULL))) {
|
NULL, NULL, NULL))) {
|
||||||
sr_err("genericdmm: sr_dev_inst_new returned NULL.");
|
sr_err("genericdmm: sr_dev_inst_new returned NULL.");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -233,6 +233,7 @@ static GSList *hw_scan(GSList *options)
|
||||||
GSList *l, *ldef, *defopts, *newopts, *devices;
|
GSList *l, *ldef, *defopts, *newopts, *devices;
|
||||||
struct sr_hwopt *opt, *defopt;
|
struct sr_hwopt *opt, *defopt;
|
||||||
struct dev_profile *pr, *profile;
|
struct dev_profile *pr, *profile;
|
||||||
|
struct sr_dev_inst *sdi;
|
||||||
const char *model;
|
const char *model;
|
||||||
|
|
||||||
/* Separate model from the options list. */
|
/* Separate model from the options list. */
|
||||||
|
@ -247,7 +248,7 @@ static GSList *hw_scan(GSList *options)
|
||||||
newopts = g_slist_append(newopts, opt);
|
newopts = g_slist_append(newopts, opt);
|
||||||
}
|
}
|
||||||
if (!model) {
|
if (!model) {
|
||||||
sr_err("Need a model to scan for.");
|
/* This driver only works when a model is specified. */
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -305,10 +306,21 @@ static GSList *hw_scan(GSList *options)
|
||||||
|
|
||||||
if (devices) {
|
if (devices) {
|
||||||
/* TODO: need to fix up sdi->index fields */
|
/* TODO: need to fix up sdi->index fields */
|
||||||
|
for (l = devices; l; l = l->next) {
|
||||||
|
/* The default connection-based scanner doesn't really
|
||||||
|
* know about profiles, so it never filled in the vendor
|
||||||
|
* or model. Do that now.
|
||||||
|
*/
|
||||||
|
sdi = l->data;
|
||||||
|
sdi->driver = gdi;
|
||||||
|
if (!sdi->vendor)
|
||||||
|
sdi->vendor = g_strdup(profile->vendor);
|
||||||
|
if (!sdi->model)
|
||||||
|
sdi->model = g_strdup(profile->model);
|
||||||
/* Add a copy of these new devices to the driver instances. */
|
/* Add a copy of these new devices to the driver instances. */
|
||||||
for (l = devices; l; l = l->next)
|
|
||||||
gdi->instances = g_slist_append(gdi->instances, l->data);
|
gdi->instances = g_slist_append(gdi->instances, l->data);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return devices;
|
return devices;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue