Browse Source

Keep the libusb event handle polling thread active until there are no async usb transfers in progress.

nfactor-troky
Con Kolivas 11 years ago
parent
commit
81dfe60d36
  1. 15
      cgminer.c
  2. 2
      usbutils.h

15
cgminer.c

@ -7798,17 +7798,24 @@ static void probe_pools(void) @@ -7798,17 +7798,24 @@ static void probe_pools(void)
#ifdef USE_USBUTILS
static void *libusb_poll_thread(void __maybe_unused *arg)
{
struct timeval tv_end = {0, 100000};
struct timeval tv_end = {1, 0};
bool inprogress = false;
RenameThread("usbpoll");
while (usb_polling)
libusb_handle_events_timeout_completed(NULL, &tv_end, NULL);
/* One longer poll on shut down to enable drivers to hopefully cleanly
* shut down. */
tv_end.tv_sec = 1;
/* Keep event handling going until there are no async transfers in
* flight. */
do {
libusb_handle_events_timeout_completed(NULL, &tv_end, NULL);
cg_rlock(&cgusb_fd_lock);
inprogress = !!cgusb_transfers;
cg_runlock(&cgusb_fd_lock);
} while (inprogress);
return NULL;
}

2
usbutils.h

@ -117,6 +117,8 @@ @@ -117,6 +117,8 @@
#define DEFAULT_EP_IN 0
#define DEFAULT_EP_OUT 1
int cgusb_transfers;
struct usb_epinfo {
uint8_t att;
uint16_t size;

Loading…
Cancel
Save