aboutsummaryrefslogtreecommitdiffstats
path: root/cphidgetmanager.c
diff options
context:
space:
mode:
authorJonathan McCrohan <jmccrohan@gmail.com>2013-03-03 19:30:43 +0000
committerJonathan McCrohan <jmccrohan@gmail.com>2013-03-03 19:30:43 +0000
commit46bd2ba42d186a81d7ad7e4a55e03dd63b2d042f (patch)
tree21c25e277606d6a711029c8d9511f57983cbc23b /cphidgetmanager.c
parent8f3c91e91b634adaca77dac6cf314445cceefc78 (diff)
downloadlibphidget21-46bd2ba42d186a81d7ad7e4a55e03dd63b2d042f.tar.gz
Imported Upstream version 2.1.8.20121218upstream
Diffstat (limited to 'cphidgetmanager.c')
-rw-r--r--cphidgetmanager.c25
1 files changed, 18 insertions, 7 deletions
diff --git a/cphidgetmanager.c b/cphidgetmanager.c
index d0f918b..7471deb 100644
--- a/cphidgetmanager.c
+++ b/cphidgetmanager.c
@@ -177,7 +177,7 @@ static int sendInitialEvents()
int CPhidgetManager_poll()
{
CPhidgetList *curList = 0, *detachList = 0;
- CPhidgetList *trav = 0;
+ CPhidgetList *trav = 0, *trav2 = 0;
CPhidgetHandle foundPhidget;
if(!managerLockInitialized)
@@ -203,8 +203,7 @@ int CPhidgetManager_poll()
}
for (trav=curList; trav; trav = trav->next)
{
- if(CList_findInList((CListHandle)AttachedDevices, trav->phid, CPhidget_areExtraEqual, NULL) ==
- EPHIDGET_NOTFOUND)
+ if(CList_findInList((CListHandle)AttachedDevices, trav->phid, CPhidget_areExtraEqual, NULL) == EPHIDGET_NOTFOUND)
{
CPhidgetAttachEvent(trav->phid);
}
@@ -215,15 +214,27 @@ int CPhidgetManager_poll()
CThread_mutex_lock(&activeDevicesLock);
if(CList_findInList((CListHandle)ActiveDevices, trav->phid, CPhidget_areEqual, (void **)&foundPhidget) == EPHIDGET_OK)
{
- if(CPhidget_statusFlagIsSet(foundPhidget->status, PHIDGET_ATTACHED_FLAG))
+ if(CPhidget_statusFlagIsSet(foundPhidget->status, PHIDGET_ATTACHED_FLAG)
+ && CPhidget_statusFlagIsSet(foundPhidget->status, PHIDGET_USB_ERROR_FLAG))
{
- if(CPhidget_statusFlagIsSet(foundPhidget->status, PHIDGET_USB_ERROR_FLAG))
+ LOG(PHIDGET_LOG_WARNING,"PHIDGET_USB_ERROR_FLAG is set - cycling device through a detach");
+ CList_addToList((CListHandle *)&detachList, trav->phid, CPhidget_areEqual);
+
+ //if this is a composite device, we must find it's pair and detach that as well.
+ //same serial, but different interface num
+ for (trav2=curList; trav2; trav2 = trav2->next)
{
- LOG(PHIDGET_LOG_WARNING,"PHIDGET_USB_ERROR_FLAG is set - cycling device through a detach");
- CList_addToList((CListHandle *)&detachList, trav->phid, CPhidget_areEqual);
+ if(trav->phid->serialNumber == trav2->phid->serialNumber
+ && trav->phid->deviceDef->pdd_iid != trav2->phid->deviceDef->pdd_iid)
+ {
+ LOG(PHIDGET_LOG_WARNING,"PHIDGET_USB_ERROR_FLAG is set - cycling composite device 2nd interface through a detach");
+ CList_addToList((CListHandle *)&detachList, trav2->phid, CPhidget_areEqual);
+ }
}
}
}
+
+
CThread_mutex_unlock(&activeDevicesLock);
}
for (trav=detachList; trav; trav = trav->next)