summaryrefslogtreecommitdiffstats
path: root/gfx/thebes/DeviceManagerDx.cpp
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-12 05:35:37 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-12 05:35:37 +0000
commita90a5cba08fdf6c0ceb95101c275108a152a3aed (patch)
tree532507288f3defd7f4dcf1af49698bcb76034855 /gfx/thebes/DeviceManagerDx.cpp
parentAdding debian version 126.0.1-1. (diff)
downloadfirefox-a90a5cba08fdf6c0ceb95101c275108a152a3aed.tar.xz
firefox-a90a5cba08fdf6c0ceb95101c275108a152a3aed.zip
Merging upstream version 127.0.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'gfx/thebes/DeviceManagerDx.cpp')
-rw-r--r--gfx/thebes/DeviceManagerDx.cpp70
1 files changed, 2 insertions, 68 deletions
diff --git a/gfx/thebes/DeviceManagerDx.cpp b/gfx/thebes/DeviceManagerDx.cpp
index 3a531e92ae..cfd1169e95 100644
--- a/gfx/thebes/DeviceManagerDx.cpp
+++ b/gfx/thebes/DeviceManagerDx.cpp
@@ -264,7 +264,7 @@ void DeviceManagerDx::UpdateMonitorInfo() {
bool systemHdrEnabled = false;
std::set<HMONITOR> hdrMonitors;
- for (const auto& desc : GetOutputDescs()) {
+ for (const auto desc : EnumerateOutputs()) {
if (ColorSpaceIsHDR(desc)) {
systemHdrEnabled = true;
hdrMonitors.emplace(desc.Monitor);
@@ -279,72 +279,6 @@ void DeviceManagerDx::UpdateMonitorInfo() {
}
}
-std::vector<DXGI_OUTPUT_DESC1> DeviceManagerDx::GetOutputDescs() {
- std::vector<DXGI_OUTPUT_DESC1> outputDescs;
-
- nsModuleHandle dxgiModule(LoadLibrarySystem32(L"dxgi.dll"));
- decltype(CreateDXGIFactory1)* createDXGIFactory1 =
- (decltype(CreateDXGIFactory1)*)GetProcAddress(dxgiModule,
- "CreateDXGIFactory1");
- if (!createDXGIFactory1) {
- return outputDescs;
- }
-
- RefPtr<IDXGIFactory1> dxgiFactory;
- HRESULT hr =
- createDXGIFactory1(__uuidof(IDXGIFactory1), getter_AddRefs(dxgiFactory));
- if (FAILED(hr)) {
- gfxCriticalNoteOnce << "Failed to create DXGI factory: " << gfx::hexa(hr);
- return outputDescs;
- }
-
- for (UINT adapterIndex = 0;; adapterIndex++) {
- RefPtr<IDXGIAdapter> adapter;
- hr = dxgiFactory->EnumAdapters(adapterIndex, getter_AddRefs(adapter));
- if (hr == DXGI_ERROR_NOT_FOUND) {
- break;
- }
- if (FAILED(hr)) {
- MOZ_ASSERT_UNREACHABLE("unexpected to be called");
- gfxCriticalNoteOnce << "Failed to enumerate DXGI adapter: "
- << gfx::hexa(hr);
- break;
- }
-
- for (UINT outputIndex = 0;; ++outputIndex) {
- RefPtr<IDXGIOutput> output;
- hr = adapter->EnumOutputs(outputIndex, getter_AddRefs(output));
- if (hr == DXGI_ERROR_NOT_FOUND) {
- break;
- }
- if (FAILED(hr)) {
- MOZ_ASSERT_UNREACHABLE("unexpected to be called");
- gfxCriticalNoteOnce << "Failed to enumulate DXGI output: "
- << gfx::hexa(hr);
- break;
- }
-
- RefPtr<IDXGIOutput6> output6;
- hr = output->QueryInterface(__uuidof(IDXGIOutput6),
- getter_AddRefs(output6));
- if (FAILED(hr)) {
- continue;
- }
-
- DXGI_OUTPUT_DESC1 desc;
- if (FAILED(output6->GetDesc1(&desc))) {
- MOZ_ASSERT_UNREACHABLE("unexpected to be called");
- gfxCriticalNoteOnce << "Failed to get DXGI output descriptor";
- continue;
- }
-
- outputDescs.push_back(std::move(desc));
- }
- }
-
- return outputDescs;
-}
-
bool DeviceManagerDx::SystemHDREnabled() {
{
MutexAutoLock lock(mDeviceLock);
@@ -704,7 +638,7 @@ void DeviceManagerDx::CreateContentDevicesLocked() {
// We should have been assigned a DeviceStatus from the parent process,
// GPU process, or the same process if using in-process compositing.
- MOZ_ASSERT(mDeviceStatus);
+ MOZ_RELEASE_ASSERT(mDeviceStatus);
if (CreateContentDevice() == FeatureStatus::CrashedInHandler) {
DisableD3D11AfterCrash();