mirror of
https://github.com/doitsujin/dxvk.git
synced 2025-01-19 05:52:11 +01:00
[d3d11] Move D3D11UserDefinedAnnotation member to D3D11CommonContext
This needs to be temlpated because we'll be moving EmitCs to the common implementation as well, and make EmitCsChunk non-virtual.
This commit is contained in:
parent
10345d0063
commit
3f5f731c42
@ -1,5 +1,6 @@
|
||||
#include "d3d11_annotation.h"
|
||||
#include "d3d11_context.h"
|
||||
#include "d3d11_context_def.h"
|
||||
#include "d3d11_context_imm.h"
|
||||
#include "d3d11_device.h"
|
||||
|
||||
#include "../util/util_misc.h"
|
||||
@ -30,40 +31,47 @@ namespace dxvk {
|
||||
registrationFunction(annotation);
|
||||
}
|
||||
|
||||
D3D11UserDefinedAnnotation::D3D11UserDefinedAnnotation(
|
||||
D3D11DeviceContext* container,
|
||||
|
||||
template<typename ContextType>
|
||||
D3D11UserDefinedAnnotation<ContextType>::D3D11UserDefinedAnnotation(
|
||||
ContextType* container,
|
||||
const Rc<DxvkDevice>& dxvkDevice)
|
||||
: m_container(container), m_eventDepth(0),
|
||||
m_annotationsEnabled(dxvkDevice->instance()->extensions().extDebugUtils) {
|
||||
if (m_annotationsEnabled)
|
||||
if (!IsDeferred && m_annotationsEnabled)
|
||||
RegisterUserDefinedAnnotation<true>(this);
|
||||
}
|
||||
|
||||
|
||||
D3D11UserDefinedAnnotation::~D3D11UserDefinedAnnotation() {
|
||||
if (m_annotationsEnabled)
|
||||
template<typename ContextType>
|
||||
D3D11UserDefinedAnnotation<ContextType>::~D3D11UserDefinedAnnotation() {
|
||||
if (!IsDeferred && m_annotationsEnabled)
|
||||
RegisterUserDefinedAnnotation<false>(this);
|
||||
}
|
||||
|
||||
|
||||
ULONG STDMETHODCALLTYPE D3D11UserDefinedAnnotation::AddRef() {
|
||||
template<typename ContextType>
|
||||
ULONG STDMETHODCALLTYPE D3D11UserDefinedAnnotation<ContextType>::AddRef() {
|
||||
return m_container->AddRef();
|
||||
}
|
||||
|
||||
|
||||
ULONG STDMETHODCALLTYPE D3D11UserDefinedAnnotation::Release() {
|
||||
template<typename ContextType>
|
||||
ULONG STDMETHODCALLTYPE D3D11UserDefinedAnnotation<ContextType>::Release() {
|
||||
return m_container->Release();
|
||||
}
|
||||
|
||||
|
||||
HRESULT STDMETHODCALLTYPE D3D11UserDefinedAnnotation::QueryInterface(
|
||||
template<typename ContextType>
|
||||
HRESULT STDMETHODCALLTYPE D3D11UserDefinedAnnotation<ContextType>::QueryInterface(
|
||||
REFIID riid,
|
||||
void** ppvObject) {
|
||||
return m_container->QueryInterface(riid, ppvObject);
|
||||
}
|
||||
|
||||
|
||||
INT STDMETHODCALLTYPE D3D11UserDefinedAnnotation::BeginEvent(
|
||||
template<typename ContextType>
|
||||
INT STDMETHODCALLTYPE D3D11UserDefinedAnnotation<ContextType>::BeginEvent(
|
||||
D3DCOLOR Color,
|
||||
LPCWSTR Name) {
|
||||
if (!m_annotationsEnabled)
|
||||
@ -85,7 +93,8 @@ namespace dxvk {
|
||||
}
|
||||
|
||||
|
||||
INT STDMETHODCALLTYPE D3D11UserDefinedAnnotation::EndEvent() {
|
||||
template<typename ContextType>
|
||||
INT STDMETHODCALLTYPE D3D11UserDefinedAnnotation<ContextType>::EndEvent() {
|
||||
if (!m_annotationsEnabled)
|
||||
return -1;
|
||||
|
||||
@ -99,7 +108,8 @@ namespace dxvk {
|
||||
}
|
||||
|
||||
|
||||
void STDMETHODCALLTYPE D3D11UserDefinedAnnotation::SetMarker(
|
||||
template<typename ContextType>
|
||||
void STDMETHODCALLTYPE D3D11UserDefinedAnnotation<ContextType>::SetMarker(
|
||||
D3DCOLOR Color,
|
||||
LPCWSTR Name) {
|
||||
if (!m_annotationsEnabled)
|
||||
@ -119,8 +129,13 @@ namespace dxvk {
|
||||
}
|
||||
|
||||
|
||||
BOOL STDMETHODCALLTYPE D3D11UserDefinedAnnotation::GetStatus() {
|
||||
template<typename ContextType>
|
||||
BOOL STDMETHODCALLTYPE D3D11UserDefinedAnnotation<ContextType>::GetStatus() {
|
||||
return m_annotationsEnabled;
|
||||
}
|
||||
|
||||
|
||||
template class D3D11UserDefinedAnnotation<D3D11DeferredContext>;
|
||||
template class D3D11UserDefinedAnnotation<D3D11ImmediateContext>;
|
||||
|
||||
}
|
||||
|
@ -1,5 +1,7 @@
|
||||
#pragma once
|
||||
|
||||
#include <type_traits>
|
||||
|
||||
#include "d3d11_include.h"
|
||||
|
||||
#include "../dxvk/dxvk_annotation.h"
|
||||
@ -7,14 +9,16 @@
|
||||
|
||||
namespace dxvk {
|
||||
|
||||
class D3D11DeviceContext;
|
||||
class D3D11DeferredContext;
|
||||
class D3D11ImmediateContext;
|
||||
|
||||
template<typename ContextType>
|
||||
class D3D11UserDefinedAnnotation final : public IDXVKUserDefinedAnnotation {
|
||||
|
||||
constexpr static bool IsDeferred = std::is_same_v<ContextType, D3D11DeferredContext>;
|
||||
public:
|
||||
|
||||
D3D11UserDefinedAnnotation(
|
||||
D3D11DeviceContext* container,
|
||||
ContextType* container,
|
||||
const Rc<DxvkDevice>& dxvkDevice);
|
||||
|
||||
~D3D11UserDefinedAnnotation();
|
||||
@ -44,7 +48,7 @@ namespace dxvk {
|
||||
|
||||
private:
|
||||
|
||||
D3D11DeviceContext* m_container;
|
||||
ContextType* m_container;
|
||||
int32_t m_eventDepth;
|
||||
bool m_annotationsEnabled;
|
||||
};
|
||||
|
@ -19,7 +19,6 @@ namespace dxvk {
|
||||
m_multithread(this, false),
|
||||
m_device (Device),
|
||||
m_staging (Device, StagingBufferSize),
|
||||
m_annotation(this, Device),
|
||||
m_csFlags (CsFlags),
|
||||
m_csChunk (AllocCsChunk()),
|
||||
m_cmdData (nullptr) {
|
||||
@ -2780,11 +2779,6 @@ namespace dxvk {
|
||||
}
|
||||
|
||||
|
||||
BOOL STDMETHODCALLTYPE D3D11DeviceContext::IsAnnotationEnabled() {
|
||||
return m_annotation.GetStatus();
|
||||
}
|
||||
|
||||
|
||||
void STDMETHODCALLTYPE D3D11DeviceContext::SetMarkerInt(
|
||||
LPCWSTR pLabel,
|
||||
INT Data) {
|
||||
|
@ -21,6 +21,7 @@ namespace dxvk {
|
||||
class D3D11DeviceContext : public D3D11DeviceChild<ID3D11DeviceContext4> {
|
||||
friend class D3D11DeviceContextExt;
|
||||
// Needed in order to call EmitCs for pushing markers
|
||||
template<typename T>
|
||||
friend class D3D11UserDefinedAnnotation;
|
||||
|
||||
constexpr static VkDeviceSize StagingBufferSize = 4ull << 20;
|
||||
@ -658,8 +659,6 @@ namespace dxvk {
|
||||
ID3D11Buffer** ppSOTargets,
|
||||
UINT* pOffsets);
|
||||
|
||||
BOOL STDMETHODCALLTYPE IsAnnotationEnabled();
|
||||
|
||||
void STDMETHODCALLTYPE SetMarkerInt(
|
||||
LPCWSTR pLabel,
|
||||
INT Data);
|
||||
@ -696,9 +695,6 @@ namespace dxvk {
|
||||
|
||||
DxvkStagingBuffer m_staging;
|
||||
|
||||
//has to be declared after m_device, as compiler initialize in order of declaration in the class
|
||||
D3D11UserDefinedAnnotation m_annotation;
|
||||
|
||||
DxvkCsChunkFlags m_csFlags;
|
||||
DxvkCsChunkRef m_csChunk;
|
||||
|
||||
|
@ -9,7 +9,8 @@ namespace dxvk {
|
||||
D3D11Device* pParent,
|
||||
const Rc<DxvkDevice>& Device,
|
||||
DxvkCsChunkFlags CsFlags)
|
||||
: D3D11DeviceContext(pParent, Device, CsFlags) {
|
||||
: D3D11DeviceContext(pParent, Device, CsFlags),
|
||||
m_annotation(static_cast<ContextType*>(this), Device) {
|
||||
|
||||
}
|
||||
|
||||
@ -88,6 +89,12 @@ namespace dxvk {
|
||||
}
|
||||
|
||||
|
||||
template<typename ContextType>
|
||||
BOOL STDMETHODCALLTYPE D3D11CommonContext<ContextType>::IsAnnotationEnabled() {
|
||||
return m_annotation.GetStatus();
|
||||
}
|
||||
|
||||
|
||||
template<typename ContextType>
|
||||
void D3D11CommonContext<ContextType>::UpdateResource(
|
||||
ID3D11Resource* pDstResource,
|
||||
|
@ -85,8 +85,12 @@ namespace dxvk {
|
||||
UINT SrcDepthPitch,
|
||||
UINT CopyFlags);
|
||||
|
||||
BOOL STDMETHODCALLTYPE IsAnnotationEnabled();
|
||||
|
||||
protected:
|
||||
|
||||
D3D11UserDefinedAnnotation<ContextType> m_annotation;
|
||||
|
||||
void UpdateResource(
|
||||
ID3D11Resource* pDstResource,
|
||||
UINT DstSubresource,
|
||||
|
Loading…
x
Reference in New Issue
Block a user