Edit

kc3-lang/angle/src/gpu_info_util/SystemInfo_linux.cpp

Branch :

  • Show log

    Commit

  • Author : Jonah Ryan-Davis
    Date : 2019-04-25 10:49:05
    Hash : 66e4850d
    Message : Use EnumAdapters to properly detect primary GPU on Win EnumDisplayDevicesA returns the card that's connected to the display, but EnumAdapters return the adapter which the desktop primary is displayed at index 0. We can use this to determine the device used for graphics. Also cleans up the discrepancy between platforms on finding "primary" vs "active" GPU. Asserts that the GPU expected to run ANGLE commands is the active GPU, and deprecates the primary GPU to be equal to the active GPU. Bug: angleproject:3383 Change-Id: I422fba1bbe47d85b7c09e378d559eaebf89e2625 Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/1584360 Commit-Queue: Jonah Ryan-Davis <jonahr@google.com> Reviewed-by: Geoff Lang <geofflang@chromium.org>

  • src/gpu_info_util/SystemInfo_linux.cpp
  • //
    // Copyright (c) 2013-2017 The ANGLE Project Authors. All rights reserved.
    // Use of this source code is governed by a BSD-style license that can be
    // found in the LICENSE file.
    //
    
    // SystemInfo_linux.cpp: implementation of the Linux-specific parts of SystemInfo.h
    
    #include "gpu_info_util/SystemInfo_internal.h"
    
    #include <cstring>
    #include <fstream>
    
    #include "common/angleutils.h"
    #include "common/debug.h"
    
    namespace angle
    {
    
    namespace
    {
    
    bool ReadWholeFile(const char *filename, std::string *content)
    {
        std::ifstream file(filename);
    
        if (!file)
        {
            return false;
        }
    
        *content = std::string(std::istreambuf_iterator<char>(file), std::istreambuf_iterator<char>());
        return true;
    }
    
    // Scan /sys/module/amdgpu/version.
    bool GetAMDBrahmaDriverVersion(std::string *version)
    {
        *version = "";
        std::string content;
    
        return ReadWholeFile("/sys/module/amdgpu/version", &content) &&
               ParseAMDBrahmaDriverVersion(content, version);
    }
    
    // Scan /etc/ati/amdpcsdb.default for "ReleaseVersion".
    bool GetAMDCatalystDriverVersion(std::string *version)
    {
        *version = "";
        std::string content;
    
        return ReadWholeFile("/etc/ati/amdpcsdb.default", &content) &&
               ParseAMDCatalystDriverVersion(content, version);
    }
    
    }  // anonymous namespace
    
    #if !defined(GPU_INFO_USE_X11)
    bool GetNvidiaDriverVersionWithXNVCtrl(std::string *version)
    {
        return false;
    }
    #endif
    
    #if !defined(GPU_INFO_USE_LIBPCI)
    bool GetPCIDevicesWithLibPCI(std::vector<GPUDeviceInfo> *devices)
    {
        return false;
    }
    #endif
    
    bool GetSystemInfo(SystemInfo *info)
    {
        if (!GetPCIDevicesWithLibPCI(&(info->gpus)))
        {
            return false;
        }
    
        if (info->gpus.size() == 0)
        {
            return false;
        }
    
        FindActiveGPU(info);
    
        for (size_t i = 0; i < info->gpus.size(); ++i)
        {
            GPUDeviceInfo *gpu = &info->gpus[i];
    
            // New GPUs might be added inside this loop, don't query for their driver version again
            if (!gpu->driverVendor.empty())
            {
                continue;
            }
    
            if (IsAMD(gpu->vendorId))
            {
                std::string version;
                if (GetAMDBrahmaDriverVersion(&version))
                {
                    gpu->driverVendor  = "AMD (Brahma)";
                    gpu->driverVersion = std::move(version);
                }
                else if (GetAMDCatalystDriverVersion(&version))
                {
                    gpu->driverVendor  = "AMD (Catalyst)";
                    gpu->driverVersion = std::move(version);
                }
            }
    
            if (IsNVIDIA(gpu->vendorId))
            {
                std::string version;
                if (GetNvidiaDriverVersionWithXNVCtrl(&version))
                {
                    gpu->driverVendor  = "Nvidia";
                    gpu->driverVersion = std::move(version);
                }
            }
    
            // In dual-GPU cases the PCI scan sometimes only gives us the Intel GPU. If we are able to
            // query for the Nvidia driver version, it means there was hidden Nvidia GPU, so we add it
            // to the list.
            if (IsIntel(gpu->vendorId) && info->gpus.size() == 1)
            {
                std::string version;
                if (GetNvidiaDriverVersionWithXNVCtrl(&version))
                {
                    GPUDeviceInfo nvidiaInfo;
                    nvidiaInfo.vendorId = kVendorID_NVIDIA;
                    nvidiaInfo.deviceId = 0;
                    gpu->driverVendor   = "Nvidia";
                    gpu->driverVersion  = std::move(version);
    
                    info->gpus.emplace_back(std::move(nvidiaInfo));
                    info->isOptimus = true;
                }
            }
        }
    
        return true;
    }
    
    }  // namespace angle