Don't reset instance list in scan() callback
Some drivers set the device instance list to NULL in their scan() callback. This means the driver loses all references to any devices contained in that list and their resources will be leaked. Drivers can't free the devices at this point either since an application might still use a device on the list. So the existing devices on the instance list need to remain unmodified during the scan() callback, even if that means that there will be duplicates on the instance list. Only an explicit invocation of sr_dev_clear() by the application is allowed to free the devices on the instance list and reset the list. Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
This commit is contained in:
parent
d268866d29
commit
566007e15e
|
@ -83,7 +83,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
char *buf, **tokens;
|
char *buf, **tokens;
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
conn = serialcomm = NULL;
|
conn = serialcomm = NULL;
|
||||||
|
|
|
@ -81,7 +81,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
sr_info("Probing serial port %s.", conn);
|
sr_info("Probing serial port %s.", conn);
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
serial_flush(serial);
|
serial_flush(serial);
|
||||||
|
|
||||||
/* Let's get a bit of data and see if we can find a packet. */
|
/* Let's get a bit of data and see if we can find a packet. */
|
||||||
|
|
|
@ -74,7 +74,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
conn = serialcomm = NULL;
|
conn = serialcomm = NULL;
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
|
|
|
@ -94,7 +94,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options, int modelid)
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
conn = serialcomm = NULL;
|
conn = serialcomm = NULL;
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
|
|
|
@ -82,7 +82,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
/* Probe for /dev/beaglelogic */
|
/* Probe for /dev/beaglelogic */
|
||||||
if (!g_file_test(BEAGLELOGIC_DEV_NODE, G_FILE_TEST_EXISTS))
|
if (!g_file_test(BEAGLELOGIC_DEV_NODE, G_FILE_TEST_EXISTS))
|
||||||
|
|
|
@ -44,7 +44,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
const char *conn;
|
const char *conn;
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
conn = BRYMEN_BC86X;
|
conn = BRYMEN_BC86X;
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
|
|
|
@ -97,7 +97,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
conn = serialcomm = NULL;
|
conn = serialcomm = NULL;
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
|
|
|
@ -149,7 +149,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
char product[64], serial_num[64], connection_id[64];
|
char product[64], serial_num[64], connection_id[64];
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
conn = NULL;
|
conn = NULL;
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
|
|
|
@ -52,7 +52,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
const char *conn, *serialcomm;
|
const char *conn, *serialcomm;
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
|
|
||||||
|
|
|
@ -50,7 +50,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
conn = serialcomm = NULL;
|
conn = serialcomm = NULL;
|
||||||
|
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
|
|
|
@ -209,7 +209,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
conn = NULL;
|
conn = NULL;
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
src = l->data;
|
src = l->data;
|
||||||
|
|
|
@ -155,7 +155,6 @@ static GSList *scan_1x_2x_rs232(struct sr_dev_driver *di, GSList *options)
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
conn = serialcomm = NULL;
|
conn = serialcomm = NULL;
|
||||||
serialcomm_given = FALSE;
|
serialcomm_given = FALSE;
|
||||||
|
|
||||||
|
@ -249,7 +248,6 @@ static GSList *scan_2x_bd232(struct sr_dev_driver *di, GSList *options)
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
sr_spew("scan_2x_bd232() called!");
|
sr_spew("scan_2x_bd232() called!");
|
||||||
|
|
||||||
|
|
|
@ -67,7 +67,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
usb_devices = sr_usb_find(drvc->sr_ctx->libusb_ctx, USB_VID_PID);
|
usb_devices = sr_usb_find(drvc->sr_ctx->libusb_ctx, USB_VID_PID);
|
||||||
|
|
||||||
|
|
|
@ -112,7 +112,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
(void)options;
|
(void)options;
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
if ((usb_devices = sr_usb_find(drvc->sr_ctx->libusb_ctx, USB_CONN))) {
|
if ((usb_devices = sr_usb_find(drvc->sr_ctx->libusb_ctx, USB_CONN))) {
|
||||||
|
|
|
@ -79,7 +79,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
conn = NULL;
|
conn = NULL;
|
||||||
serialcomm = NULL;
|
serialcomm = NULL;
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
src = l->data;
|
src = l->data;
|
||||||
|
|
|
@ -120,7 +120,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
(void)options;
|
(void)options;
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
|
|
||||||
|
|
|
@ -86,7 +86,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
char reply[50], **tokens, *dummy;
|
char reply[50], **tokens, *dummy;
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
conn = NULL;
|
conn = NULL;
|
||||||
serialcomm = NULL;
|
serialcomm = NULL;
|
||||||
|
|
|
@ -384,7 +384,6 @@ static GSList *do_scan(lps_modelid modelid, struct sr_dev_driver *drv, GSList *o
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
|
|
||||||
drvc = drv->context;
|
drvc = drv->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
sr_spew("scan() called!");
|
sr_spew("scan() called!");
|
||||||
|
|
||||||
|
|
|
@ -80,7 +80,6 @@ static GSList *scan(struct sr_dev_driver *drv, GSList *options)
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
drvc = drv->context;
|
drvc = drv->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
conn = serialcomm = NULL;
|
conn = serialcomm = NULL;
|
||||||
|
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
|
|
|
@ -74,7 +74,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
sr_info("Probing serial port %s.", conn);
|
sr_info("Probing serial port %s.", conn);
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
serial_flush(serial);
|
serial_flush(serial);
|
||||||
|
|
||||||
/* Let's get a bit of data and see if we can find a packet. */
|
/* Let's get a bit of data and see if we can find a packet. */
|
||||||
|
|
|
@ -58,7 +58,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
conn_devices = NULL;
|
conn_devices = NULL;
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
|
|
|
@ -50,7 +50,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
struct sr_serial_dev_inst *serial;
|
struct sr_serial_dev_inst *serial;
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
devices = NULL;
|
devices = NULL;
|
||||||
|
|
||||||
|
|
|
@ -48,7 +48,6 @@ static GSList *scan(struct sr_dev_driver *di, GSList *options)
|
||||||
const char *conn;
|
const char *conn;
|
||||||
|
|
||||||
drvc = di->context;
|
drvc = di->context;
|
||||||
drvc->instances = NULL;
|
|
||||||
|
|
||||||
conn = NULL;
|
conn = NULL;
|
||||||
for (l = options; l; l = l->next) {
|
for (l = options; l; l = l->next) {
|
||||||
|
|
Loading…
Reference in New Issue