1
0
mirror of https://github.com/doitsujin/dxvk.git synced 2025-01-07 16:46:17 +01:00

[util] Add function to cache QueryInterface errors

This commit is contained in:
Philip Rebohle 2023-03-01 13:01:48 +01:00
parent 81440340ac
commit aa92cf48f5
2 changed files with 51 additions and 0 deletions

View File

@ -1,9 +1,47 @@
#include <mutex>
#include <unordered_set>
#include "com_guid.h" #include "com_guid.h"
#include "../../d3d11/d3d11_interfaces.h" #include "../../d3d11/d3d11_interfaces.h"
#include "../../dxgi/dxgi_interfaces.h" #include "../../dxgi/dxgi_interfaces.h"
#include "../../dxvk/dxvk_hash.h"
#include "../thread.h"
namespace dxvk {
struct GuidPair {
GuidPair() { };
GuidPair(IID a_, IID b_)
: a(a_), b(b_) { }
IID a, b;
size_t hash() const {
return size_t(a.Data1) ^ size_t(b.Data1);
}
bool eq(const GuidPair& other) const {
return a == other.a && b == other.b;
}
};
dxvk::mutex g_loggedQueryInterfaceErrorMutex;
std::unordered_set<GuidPair, DxvkHash, DxvkEq> g_loggedQueryInterfaceErrors;
bool logQueryInterfaceError(REFIID objectGuid, REFIID requestedGuid) {
if (Logger::logLevel() > LogLevel::Warn)
return false;
std::lock_guard lock(g_loggedQueryInterfaceErrorMutex);
return g_loggedQueryInterfaceErrors.emplace(objectGuid, requestedGuid).second;
}
}
std::ostream& operator << (std::ostream& os, REFIID guid) { std::ostream& operator << (std::ostream& os, REFIID guid) {
os << std::hex << std::setfill('0') os << std::hex << std::setfill('0')
<< std::setw(8) << guid.Data1 << '-'; << std::setw(8) << guid.Data1 << '-';

View File

@ -5,4 +5,17 @@
#include "com_include.h" #include "com_include.h"
namespace dxvk {
/**
* \brief Checks whether an unknown GUID should be logged
*
* \param [in] objectGuid GUID of the object that QueryInterface is called on
* \param [in] requestGuid Requested unsupported GUID
* \returns \c true if the error should be logged
*/
bool logQueryInterfaceError(REFIID objectGuid, REFIID requestedGuid);
};
std::ostream& operator << (std::ostream& os, REFIID guid); std::ostream& operator << (std::ostream& os, REFIID guid);