From deb28ea45d0dd00e52026ae227d856582546ca9d Mon Sep 17 00:00:00 2001 From: Jiawei Shao Date: Tue, 1 Oct 2019 02:30:32 +0000 Subject: [PATCH] D3D12: Implement ASSERT_SUCCESS as macro instead of function This patch implements ASSERT_SUCCESS(hr) as a macro instead of a function so that when hr fails Dawn can print out the line number of the expression that causes the failure. For example, previously we will always get the following error message because ASSERT_SUCCESS is a function: Assertion failure at ../../src/dawn_native/d3d12/DeviceD3D12.cpp:43 (ASSERT_SUCCESS): (((HRESULT)(hr)) >= 0) Now we can get more details about where the failure occurs because now ASSERT_SUCCESS is a macro: Assertion failure at ../../src/dawn_native/d3d12/DeviceD3D12.cpp:59 (Initialize): (((HRESULT)(mD3d12Device->CreateCommandQueue(&queueDesc, __uuidof(**(&mFence)), IID_PPV_ARGS_Helper(&mFence)))) >= 0) BUG=dawn:178 Change-Id: I435ee2f418658bca276f439fcabfabbfecbff998 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/11700 Commit-Queue: Kai Ninomiya Reviewed-by: Corentin Wallez Reviewed-by: Kai Ninomiya --- src/dawn_native/d3d12/DeviceD3D12.cpp | 4 ---- src/dawn_native/d3d12/DeviceD3D12.h | 6 +++++- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/dawn_native/d3d12/DeviceD3D12.cpp b/src/dawn_native/d3d12/DeviceD3D12.cpp index 2f535ee6ec..4c6eb3bbad 100644 --- a/src/dawn_native/d3d12/DeviceD3D12.cpp +++ b/src/dawn_native/d3d12/DeviceD3D12.cpp @@ -40,10 +40,6 @@ namespace dawn_native { namespace d3d12 { - void ASSERT_SUCCESS(HRESULT hr) { - ASSERT(SUCCEEDED(hr)); - } - Device::Device(Adapter* adapter, const DeviceDescriptor* descriptor) : DeviceBase(adapter, descriptor) { if (descriptor != nullptr) { diff --git a/src/dawn_native/d3d12/DeviceD3D12.h b/src/dawn_native/d3d12/DeviceD3D12.h index e5a373480c..a856d10ada 100644 --- a/src/dawn_native/d3d12/DeviceD3D12.h +++ b/src/dawn_native/d3d12/DeviceD3D12.h @@ -33,7 +33,11 @@ namespace dawn_native { namespace d3d12 { class PlatformFunctions; class ResourceAllocator; - void ASSERT_SUCCESS(HRESULT hr); +#define ASSERT_SUCCESS(hr) \ + { \ + HRESULT succeeded = hr; \ + ASSERT(SUCCEEDED(succeeded)); \ + } // Definition of backend types class Device : public DeviceBase {