From e3572f977fc662bdecdac4f525f415bdc7e62147 Mon Sep 17 00:00:00 2001 From: Emil Velikov Date: Thu, 5 Mar 2020 13:50:46 +0000 Subject: [PATCH 1/1] loader: simplify codeflow in drm_get_pci_id_for_fd Signed-off-by: Emil Velikov Reviewed-by: Adam Jackson Reviewed-by: Eric Engestrom Part-of: --- src/loader/loader.c | 28 ++++++++++++---------------- 1 file changed, 12 insertions(+), 16 deletions(-) diff --git a/src/loader/loader.c b/src/loader/loader.c index 1a438a4fcc7..a2e726465af 100644 --- a/src/loader/loader.c +++ b/src/loader/loader.c @@ -385,26 +385,22 @@ static bool drm_get_pci_id_for_fd(int fd, int *vendor_id, int *chip_id) { drmDevicePtr device; - bool ret; - if (drmGetDevice2(fd, 0, &device) == 0) { - if (device->bustype == DRM_BUS_PCI) { - *vendor_id = device->deviceinfo.pci->vendor_id; - *chip_id = device->deviceinfo.pci->device_id; - ret = true; - } - else { - log_(_LOADER_DEBUG, "MESA-LOADER: device is not located on the PCI bus\n"); - ret = false; - } - drmFreeDevice(&device); - } - else { + if (drmGetDevice2(fd, 0, &device) != 0) { log_(_LOADER_WARNING, "MESA-LOADER: failed to retrieve device information\n"); - ret = false; + return false; } - return ret; + if (device->bustype != DRM_BUS_PCI) { + drmFreeDevice(&device); + log_(_LOADER_DEBUG, "MESA-LOADER: device is not located on the PCI bus\n"); + return false; + } + + *vendor_id = device->deviceinfo.pci->vendor_id; + *chip_id = device->deviceinfo.pci->device_id; + drmFreeDevice(&device); + return true; } #endif -- 2.30.2