]> xenbits.xensource.com Git - libvirt.git/commitdiff
test: fix potential lock corruption in test driver
authorLaine Stump <laine@redhat.com>
Wed, 7 Dec 2011 18:52:01 +0000 (13:52 -0500)
committerLaine Stump <laine@laine.org>
Thu, 8 Dec 2011 21:20:31 +0000 (16:20 -0500)
In some error situations, the function testDomainRestoreFlags() could
unlock the test driver mutex without first locking it. This patch
moves the lock operation earlier, so that it occurs before any
potential jump down to the unlock call.

I found this problem while auditing the test driver lock usage to
determine the cause of a hang while running the following test:

  cd tests; while true; do printf x; ./undefine; done

This patch *does not* solve that problem, but we now understand its
actual source, and danpb is working on a patch.

src/test/test_driver.c

index ce94a17a56bc9e7e90789a70d403b5c27f149e59..89f7df1171c4805c4fb629acbf0986ecf524aaf3 100644 (file)
@@ -1861,6 +1861,8 @@ testDomainRestoreFlags(virConnectPtr conn,
         return -1;
     }
 
+    testDriverLock(privconn);
+
     if ((fd = open(path, O_RDONLY)) < 0) {
         virReportSystemError(errno,
                              _("cannot read domain image '%s'"),
@@ -1900,7 +1902,6 @@ testDomainRestoreFlags(virConnectPtr conn,
     }
     xml[len] = '\0';
 
-    testDriverLock(privconn);
     def = virDomainDefParseString(privconn->caps, xml,
                                   1 << VIR_DOMAIN_VIRT_TEST,
                                   VIR_DOMAIN_XML_INACTIVE);