virhostdevtest.c 17.3 KB
Newer Older
1 2
/*
 * Copyright (C) 2014 SUSE LINUX Products GmbH, Nuernberg, Germany.
3
 * Copyright (C) 2014-2016 Red Hat, Inc.
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library.  If not, see
 * <http://www.gnu.org/licenses/>.
 */

#include <config.h>

#include "testutils.h"

#ifdef __linux__

# include <sys/types.h>
# include <sys/stat.h>
# include <sys/ioctl.h>
# include <fcntl.h>
# include "virlog.h"
# include "virhostdev.h"

# define VIR_FROM_THIS VIR_FROM_NONE

35 36
VIR_LOG_INIT("tests.hostdevtest");

37
# define CHECK_LIST_COUNT(list, cnt, cb) \
38 39
    do { \
        size_t actualCount; \
40
        if ((actualCount = cb(list)) != cnt) { \
41 42 43 44 45
            virReportError(VIR_ERR_INTERNAL_ERROR, \
                           "Unexpected count of items in " #list ": %zu, " \
                           "expecting %zu", actualCount, (size_t) cnt); \
            goto cleanup; \
        } \
46
    } while (0)
47

48 49 50
# define CHECK_PCI_LIST_COUNT(list, cnt) \
    CHECK_LIST_COUNT(list, cnt, virPCIDeviceListCount)

51 52 53 54 55 56 57 58
# define TEST_STATE_DIR abs_builddir "/hostdevmgr"
static const char *drv_name = "test_driver";
static const char *dom_name = "test_domain";
static const unsigned char *uuid =
            (unsigned char *)("f92360b0-2541-8791-fb32-d1f838811541");
static int nhostdevs = 3;
static virDomainHostdevDefPtr hostdevs[] = {NULL, NULL, NULL};
static virPCIDevicePtr dev[] = {NULL, NULL, NULL};
59
static virHostdevManagerPtr mgr;
60 61 62 63 64 65 66 67 68 69 70

static void
myCleanup(void)
{
    size_t i;
    for (i = 0; i < nhostdevs; i++) {
         virPCIDeviceFree(dev[i]);
         virDomainHostdevDefFree(hostdevs[i]);
    }

    if (mgr) {
71
        if (!getenv("LIBVIRT_SKIP_CLEANUP"))
72 73
            virFileDeleteTree(mgr->stateDir);

74 75
        virObjectUnref(mgr->activePCIHostdevs);
        virObjectUnref(mgr->activeUSBHostdevs);
76 77
        virObjectUnref(mgr->inactivePCIHostdevs);
        virObjectUnref(mgr->activeSCSIHostdevs);
78 79 80 81 82 83 84 85 86 87 88 89
        VIR_FREE(mgr->stateDir);
        VIR_FREE(mgr);
    }
}

static int
myInit(void)
{
    size_t i;

    for (i = 0; i < nhostdevs; i++) {
        virDomainHostdevSubsys subsys;
J
John Ferlan 已提交
90
        hostdevs[i] = virDomainHostdevDefNew();
91 92 93 94 95 96 97 98
        if (!hostdevs[i])
            goto cleanup;
        hostdevs[i]->mode = VIR_DOMAIN_HOSTDEV_MODE_SUBSYS;
        subsys.type = VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI;
        subsys.u.pci.addr.domain = 0;
        subsys.u.pci.addr.bus = 0;
        subsys.u.pci.addr.slot = i + 1;
        subsys.u.pci.addr.function = 0;
99
        subsys.u.pci.backend = VIR_DOMAIN_HOSTDEV_PCI_BACKEND_VFIO;
100 101 102 103
        hostdevs[i]->source.subsys = subsys;
    }

    for (i = 0; i < nhostdevs; i++) {
104
        if (!(dev[i] = virPCIDeviceNew(0, 0, i + 1, 0)))
105
            goto cleanup;
106

107
        virPCIDeviceSetStubDriver(dev[i], VIR_PCI_STUB_DRIVER_VFIO);
108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126
    }

    if (VIR_ALLOC(mgr) < 0)
        goto cleanup;
    if ((mgr->activePCIHostdevs = virPCIDeviceListNew()) == NULL)
        goto cleanup;
    if ((mgr->activeUSBHostdevs = virUSBDeviceListNew()) == NULL)
        goto cleanup;
    if ((mgr->inactivePCIHostdevs = virPCIDeviceListNew()) == NULL)
        goto cleanup;
    if ((mgr->activeSCSIHostdevs = virSCSIDeviceListNew()) == NULL)
        goto cleanup;
    if (VIR_STRDUP(mgr->stateDir, TEST_STATE_DIR) < 0)
        goto cleanup;
    if (virFileMakePath(mgr->stateDir) < 0)
        goto cleanup;

    return 0;

127
 cleanup:
128 129 130 131 132
    myCleanup();
    return -1;
}

static int
133
testVirHostdevPreparePCIHostdevs_unmanaged(void)
134 135
{
    int ret = -1;
136
    size_t active_count, inactive_count, i;
137 138 139 140

    for (i = 0; i < nhostdevs; i++)
         hostdevs[i]->managed = false;

141 142
    active_count = virPCIDeviceListCount(mgr->activePCIHostdevs);
    inactive_count = virPCIDeviceListCount(mgr->inactivePCIHostdevs);
143 144

    /* Test normal functionality */
J
Jiri Denemark 已提交
145
    VIR_DEBUG("Test 0 hostdevs");
146 147 148
    if (virHostdevPreparePCIDevices(mgr, drv_name, dom_name, uuid,
                                    NULL, 0, 0) < 0)
        goto cleanup;
149 150
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
151 152

    /* Test unmanaged hostdevs */
J
Jiri Denemark 已提交
153
    VIR_DEBUG("Test >=1 unmanaged hostdevs");
154 155 156
    if (virHostdevPreparePCIDevices(mgr, drv_name, dom_name, uuid,
                                    hostdevs, nhostdevs, 0) < 0)
        goto cleanup;
157 158
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count + nhostdevs);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count - nhostdevs);
159 160

    /* Test conflict */
161 162
    active_count = virPCIDeviceListCount(mgr->activePCIHostdevs);
    inactive_count = virPCIDeviceListCount(mgr->inactivePCIHostdevs);
J
Jiri Denemark 已提交
163
    VIR_DEBUG("Test: prepare same hostdevs for same driver/domain again");
164 165 166
    if (!virHostdevPreparePCIDevices(mgr, drv_name, dom_name, uuid,
                                     &hostdevs[0], 1, 0))
        goto cleanup;
167 168
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
169

J
Jiri Denemark 已提交
170
    VIR_DEBUG("Test: prepare same hostdevs for same driver, diff domain again");
171 172 173
    if (!virHostdevPreparePCIDevices(mgr, drv_name, "test_domain1", uuid,
                                     &hostdevs[1], 1, 0))
        goto cleanup;
174 175
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
176

J
Jiri Denemark 已提交
177
    VIR_DEBUG("Test: prepare same hostdevs for diff driver/domain again");
178 179 180
    if (!virHostdevPreparePCIDevices(mgr, "test_driver1", dom_name, uuid,
                                     &hostdevs[2], 1, 0))
        goto cleanup;
181 182
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
183 184 185

    ret = 0;

186
 cleanup:
187 188 189 190 191
    return ret;

}

static int
192
testVirHostdevReAttachPCIHostdevs_unmanaged(void)
193 194
{
    int ret = -1;
195
    size_t active_count, inactive_count, i;
196 197 198

    for (i = 0; i < nhostdevs; i++) {
        if (hostdevs[i]->managed != false) {
J
Jiri Denemark 已提交
199
            VIR_DEBUG("invalid test");
200 201 202 203
            return -1;
        }
    }

204 205
    active_count = virPCIDeviceListCount(mgr->activePCIHostdevs);
    inactive_count = virPCIDeviceListCount(mgr->inactivePCIHostdevs);
206

J
Jiri Denemark 已提交
207
    VIR_DEBUG("Test 0 hostdevs");
208
    virHostdevReAttachPCIDevices(mgr, drv_name, dom_name, NULL, 0, NULL);
209 210
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
211

J
Jiri Denemark 已提交
212
    VIR_DEBUG("Test >=1 unmanaged hostdevs");
213 214
    virHostdevReAttachPCIDevices(mgr, drv_name, dom_name,
                                  hostdevs, nhostdevs, NULL);
215 216
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count - nhostdevs);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count + nhostdevs);
217 218 219

    ret = 0;

220
 cleanup:
221 222 223 224 225
    return ret;

}

static int
226
testVirHostdevPreparePCIHostdevs_managed(bool mixed)
227 228
{
    int ret = -1;
229
    size_t active_count, inactive_count, i;
230 231 232 233

    for (i = 0; i < nhostdevs; i++)
        hostdevs[i]->managed = true;

234
    active_count = virPCIDeviceListCount(mgr->activePCIHostdevs);
235
    inactive_count = virPCIDeviceListCount(mgr->inactivePCIHostdevs);
236 237

    /* Test normal functionality */
J
Jiri Denemark 已提交
238
    VIR_DEBUG("Test >=1 hostdevs");
239 240 241
    if (virHostdevPreparePCIDevices(mgr, drv_name, dom_name, uuid,
                                     hostdevs, nhostdevs, 0) < 0)
        goto cleanup;
242
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count + nhostdevs);
243 244 245 246
    /* If testing a mixed roundtrip, devices are already in the inactive list
     * before we start and are removed from it as soon as we attach them to
     * the guest */
    if (mixed)
247
        CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count - nhostdevs);
248
    else
249
        CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
250 251

    /* Test conflict */
252
    active_count = virPCIDeviceListCount(mgr->activePCIHostdevs);
253
    inactive_count = virPCIDeviceListCount(mgr->inactivePCIHostdevs);
J
Jiri Denemark 已提交
254
    VIR_DEBUG("Test: prepare same hostdevs for same driver/domain again");
255 256 257
    if (!virHostdevPreparePCIDevices(mgr, drv_name, dom_name, uuid,
                                      &hostdevs[0], 1, 0))
        goto cleanup;
258 259
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
260

J
Jiri Denemark 已提交
261
    VIR_DEBUG("Test: prepare same hostdevs for same driver, diff domain again");
262 263 264
    if (!virHostdevPreparePCIDevices(mgr, drv_name, "test_domain1", uuid,
                                      &hostdevs[1], 1, 0))
        goto cleanup;
265 266
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
267

J
Jiri Denemark 已提交
268
    VIR_DEBUG("Test: prepare same hostdevs for diff driver/domain again");
269 270 271
    if (!virHostdevPreparePCIDevices(mgr, "test_driver1", dom_name, uuid,
                                      &hostdevs[2], 1, 0))
        goto cleanup;
272 273
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
274 275 276

    ret = 0;

277
 cleanup:
278 279 280 281 282
    return ret;

}

static int
283
testVirHostdevReAttachPCIHostdevs_managed(bool mixed)
284 285
{
    int ret = -1;
286
    size_t active_count, inactive_count, i;
287 288 289

    for (i = 0; i < nhostdevs; i++) {
        if (hostdevs[i]->managed != true) {
J
Jiri Denemark 已提交
290
            VIR_DEBUG("invalid test");
291 292 293 294
            return -1;
        }
    }

295
    active_count = virPCIDeviceListCount(mgr->activePCIHostdevs);
296
    inactive_count = virPCIDeviceListCount(mgr->inactivePCIHostdevs);
297

J
Jiri Denemark 已提交
298
    VIR_DEBUG("Test 0 hostdevs");
299
    virHostdevReAttachPCIDevices(mgr, drv_name, dom_name, NULL, 0, NULL);
300 301
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
302

J
Jiri Denemark 已提交
303
    VIR_DEBUG("Test >=1 hostdevs");
304 305
    virHostdevReAttachPCIDevices(mgr, drv_name, dom_name,
                                  hostdevs, nhostdevs, NULL);
306
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count - nhostdevs);
307 308 309
    /* If testing a mixed roundtrip, devices are added back to the inactive
     * list as soon as we detach from the guest */
    if (mixed)
310
        CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count + nhostdevs);
311
    else
312
        CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
313 314 315

    ret = 0;

316
 cleanup:
317 318 319 320 321
    return ret;

}

static int
322
testVirHostdevDetachPCINodeDevice(void)
323 324
{
    int ret = -1;
325
    size_t active_count, inactive_count, i;
326 327

    for (i = 0; i < nhostdevs; i++) {
328
        active_count = virPCIDeviceListCount(mgr->activePCIHostdevs);
329
        inactive_count = virPCIDeviceListCount(mgr->inactivePCIHostdevs);
330 331
        if (virHostdevPCINodeDeviceDetach(mgr, dev[i]) < 0)
            goto cleanup;
332 333
        CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
        CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count + 1);
334 335 336 337
    }

    ret = 0;

338
 cleanup:
339 340
    return ret;
}
341

342
static int
343
testVirHostdevResetPCINodeDevice(void)
344 345
{
    int ret = -1;
346
    size_t active_count, inactive_count, i;
347 348

    for (i = 0; i < nhostdevs; i++) {
349 350
        active_count = virPCIDeviceListCount(mgr->activePCIHostdevs);
        inactive_count = virPCIDeviceListCount(mgr->inactivePCIHostdevs);
351 352
        if (virHostdevPCINodeDeviceReset(mgr, dev[i]) < 0)
            goto cleanup;
353 354
        CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
        CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
355 356 357 358
    }

    ret = 0;

359
 cleanup:
360 361 362 363 364
    return ret;

}

static int
365
testVirHostdevReAttachPCINodeDevice(void)
366 367
{
    int ret = -1;
368
    size_t active_count, inactive_count, i;
369 370

    for (i = 0; i < nhostdevs; i++) {
371
        active_count = virPCIDeviceListCount(mgr->activePCIHostdevs);
372
        inactive_count = virPCIDeviceListCount(mgr->inactivePCIHostdevs);
373 374
        if (virHostdevPCINodeDeviceReAttach(mgr, dev[i]) < 0)
            goto cleanup;
375 376
        CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
        CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count - 1);
377 378 379 380
    }

    ret = 0;

381
 cleanup:
382 383 384 385 386
    return ret;

}

static int
387
testVirHostdevUpdateActivePCIHostdevs(void)
388 389
{
    int ret = -1;
390
    size_t active_count, inactive_count;
391

392
    active_count = virPCIDeviceListCount(mgr->activePCIHostdevs);
393
    inactive_count = virPCIDeviceListCount(mgr->inactivePCIHostdevs);
394

J
Jiri Denemark 已提交
395
    VIR_DEBUG("Test 0 hostdevs");
396 397 398
    if (virHostdevUpdateActivePCIDevices(mgr, NULL, 0,
                                         drv_name, dom_name) < 0)
        goto cleanup;
399 400
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
401

J
Jiri Denemark 已提交
402
    VIR_DEBUG("Test >=1 hostdevs");
403 404 405
    if (virHostdevUpdateActivePCIDevices(mgr, hostdevs, nhostdevs,
                                         drv_name, dom_name) < 0)
        goto cleanup;
406 407
    CHECK_PCI_LIST_COUNT(mgr->activePCIHostdevs, active_count + nhostdevs);
    CHECK_PCI_LIST_COUNT(mgr->inactivePCIHostdevs, inactive_count);
408 409 410

    ret = 0;

411
 cleanup:
412 413 414
    return ret;
}

415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439
/**
 * testVirHostdevRoundtripNoGuest:
 * @opaque: unused
 *
 * Perform a roundtrip without ever assigning devices to the guest.
 *
 *   1. Detach devices from the host
 *   2. Reattach devices to the host
 */
static int
testVirHostdevRoundtripNoGuest(const void *opaque ATTRIBUTE_UNUSED)
{
    int ret = -1;

    if (testVirHostdevDetachPCINodeDevice() < 0)
        goto out;
    if (testVirHostdevReAttachPCINodeDevice() < 0)
        goto out;

    ret = 0;

 out:
    return ret;
}

440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457
/**
 * testVirHostdevRoundtripUnmanaged:
 * @opaque: unused
 *
 * Perform a roundtrip with unmanaged devices.
 *
 *   1. Detach devices from the host
 *   2. Attach devices to the guest as unmanaged
 *   3. Detach devices from the guest as unmanaged
 *   4. Reattach devices to the host
 */
static int
testVirHostdevRoundtripUnmanaged(const void *opaque ATTRIBUTE_UNUSED)
{
    int ret = -1;

    if (testVirHostdevDetachPCINodeDevice() < 0)
        goto out;
458 459 460 461
    if (testVirHostdevPreparePCIHostdevs_unmanaged() < 0)
        goto out;
    if (testVirHostdevReAttachPCIHostdevs_unmanaged() < 0)
        goto out;
462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484
    if (testVirHostdevReAttachPCINodeDevice() < 0)
        goto out;

    ret = 0;

 out:
    return ret;
}

/**
 * testVirHostdevRoundtripManaged:
 * @opaque: unused
 *
 * Perform a roundtrip with managed devices.
 *
 *   1. Attach devices to the guest as managed
 *   2. Detach devices from the guest as managed
 */
static int
testVirHostdevRoundtripManaged(const void *opaque ATTRIBUTE_UNUSED)
{
    int ret = -1;

485 486 487 488
    if (testVirHostdevPreparePCIHostdevs_managed(false) < 0)
        goto out;
    if (testVirHostdevReAttachPCIHostdevs_managed(false) < 0)
        goto out;
489 490 491 492 493 494 495

    ret = 0;

 out:
    return ret;
}

496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514
/**
 * testVirHostdevRoundtripMixed:
 * @opaque: unused
 *
 * Perform a roundtrip with managed devices but manually detach the devices
 * from the host first.
 *
 *   1. Detach devices from the host
 *   2. Attach devices to the guest as managed
 *   3. Detach devices from the guest as managed
 *   4. Reattach devices to the host
 */
static int
testVirHostdevRoundtripMixed(const void *opaque ATTRIBUTE_UNUSED)
{
    int ret = -1;

    if (testVirHostdevDetachPCINodeDevice() < 0)
        goto out;
515 516 517 518
    if (testVirHostdevPreparePCIHostdevs_managed(true) < 0)
        goto out;
    if (testVirHostdevReAttachPCIHostdevs_managed(true) < 0)
        goto out;
519 520 521 522 523 524 525 526 527
    if (testVirHostdevReAttachPCINodeDevice() < 0)
        goto out;

    ret = 0;

 out:
    return ret;
}

528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552
/**
 * testVirHostdevOther:
 * @opaque: unused
 *
 * Perform other operations on devices.
 *
 *   1. Reset devices
 *   2. Update list of active devices
 */
static int
testVirHostdevOther(const void *opaque ATTRIBUTE_UNUSED)
{
    int ret = -1;

    if (testVirHostdevResetPCINodeDevice() < 0)
        goto out;
    if (testVirHostdevUpdateActivePCIHostdevs() < 0)
        goto out;

    ret = 0;

 out:
    return ret;
}

553
# define FAKEROOTDIRTEMPLATE abs_builddir "/fakerootdir-XXXXXX"
554 555 556 557 558

static int
mymain(void)
{
    int ret = 0;
J
John Ferlan 已提交
559
    VIR_AUTOFREE(char *) fakerootdir = NULL;
560

561
    if (VIR_STRDUP_QUIET(fakerootdir, FAKEROOTDIRTEMPLATE) < 0) {
562 563 564 565
        fprintf(stderr, "Out of memory\n");
        abort();
    }

566 567
    if (!mkdtemp(fakerootdir)) {
        fprintf(stderr, "Cannot create fakerootdir");
568 569 570
        abort();
    }

571
    setenv("LIBVIRT_FAKE_ROOT_DIR", fakerootdir, 1);
572

573 574 575 576 577
# define DO_TEST(fnc) \
    do { \
        VIR_DEBUG("Testing: %s", #fnc); \
        if (virTestRun(#fnc, fnc, NULL) < 0) \
            ret = -1; \
578 579
    } while (0)

580
    if (myInit() < 0) {
581
        fprintf(stderr, "Init data structures failed.");
582 583 584
        virFileDeleteTree(fakerootdir);
        return EXIT_FAILURE;
    }
585

586
    DO_TEST(testVirHostdevRoundtripNoGuest);
587 588
    DO_TEST(testVirHostdevRoundtripUnmanaged);
    DO_TEST(testVirHostdevRoundtripManaged);
589
    DO_TEST(testVirHostdevRoundtripMixed);
590
    DO_TEST(testVirHostdevOther);
591 592 593 594

    myCleanup();

    if (getenv("LIBVIRT_SKIP_CLEANUP") == NULL)
595
        virFileDeleteTree(fakerootdir);
596

597
    return ret == 0 ? EXIT_SUCCESS : EXIT_FAILURE;
598 599
}

600
VIR_TEST_MAIN_PRELOAD(mymain, VIR_TEST_MOCK("virpci"))
601 602 603 604 605 606 607
#else
int
main(void)
{
    return EXIT_AM_SKIP;
}
#endif