From: Emil Velikov Date: Thu, 5 Mar 2020 13:50:46 +0000 (+0000) Subject: loader: simplify codeflow in drm_get_pci_id_for_fd X-Git-Url: https://git.libre-soc.org/?p=mesa.git;a=commitdiff_plain;h=e3572f977fc662bdecdac4f525f415bdc7e62147;hp=164f4a9a4a32b8e638ce3f3c684d147d70a3b1de 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: --- 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