]> sigrok.org Git - libsigrok.git/commitdiff
usb: Enforce that there can only be one USB event source for now.
authorMartin Ling <redacted>
Sun, 22 Dec 2013 17:27:13 +0000 (17:27 +0000)
committerMartin Ling <redacted>
Sun, 22 Dec 2013 17:27:13 +0000 (17:27 +0000)
hardware/common/usb.c
libsigrok-internal.h

index 64f887de91458c7a0ac75ff6c89168dba5170ff8..c4d78f90a236acd036c4ad7e60a1ea902f225fa1 100644 (file)
@@ -277,6 +277,11 @@ SR_PRIV int usb_callback(int fd, int revents, void *cb_data)
 SR_PRIV int usb_source_add(struct sr_context *ctx, int timeout,
                sr_receive_data_callback_t cb, void *cb_data)
 {
+       if (ctx->usb_source_present) {
+               sr_err("A USB event source is already present.");
+               return SR_ERR;
+       }
+
 #ifdef _WIN32
        ctx->usb_event = CreateEvent(NULL, TRUE, FALSE, NULL);
        g_mutex_init(&ctx->usb_mutex);
@@ -296,12 +301,16 @@ SR_PRIV int usb_source_add(struct sr_context *ctx, int timeout,
                sr_source_add(lupfd[i]->fd, lupfd[i]->events, timeout, cb, cb_data);
        free(lupfd);
 #endif
+       ctx->usb_source_present = TRUE;
 
        return SR_OK;
 }
 
 SR_PRIV int usb_source_remove(struct sr_context *ctx)
 {
+       if (!ctx->usb_source_present)
+               return SR_OK;
+
 #ifdef _WIN32
        ctx->usb_thread_running = FALSE;
        g_mutex_unlock(&ctx->usb_mutex);
@@ -319,6 +328,7 @@ SR_PRIV int usb_source_remove(struct sr_context *ctx)
                sr_source_remove(lupfd[i]->fd);
        free(lupfd);
 #endif
+       ctx->usb_source_present = FALSE;
 
        return SR_OK;
 }
index a3fe2afe897beda1a6c46c5d27c501d30cb5a07b..c76f5983b7bddccf1d9388d0334ad0822c7fea5d 100644 (file)
@@ -60,6 +60,7 @@
 struct sr_context {
 #ifdef HAVE_LIBUSB_1_0
        libusb_context *libusb_ctx;
+       gboolean usb_source_present;
 #ifdef _WIN32
        GThread *usb_thread;
        gboolean usb_thread_running;