HostDisplay: Remove levels/layers from HostDisplayTexture

Wasn't implemented for updates, and we're not going to use it any time
soon.
This commit is contained in:
Connor McLaughlin 2022-01-20 21:16:12 +10:00 committed by refractionpcsx2
parent 3caebb31ae
commit e3b4d13c47
7 changed files with 19 additions and 50 deletions

View File

@ -35,14 +35,11 @@ class D3D11HostDisplayTexture : public HostDisplayTexture
{ {
public: public:
D3D11HostDisplayTexture(Microsoft::WRL::ComPtr<ID3D11Texture2D> texture, D3D11HostDisplayTexture(Microsoft::WRL::ComPtr<ID3D11Texture2D> texture,
Microsoft::WRL::ComPtr<ID3D11ShaderResourceView> srv, u32 width, u32 height, u32 layers, Microsoft::WRL::ComPtr<ID3D11ShaderResourceView> srv, u32 width, u32 height, bool dynamic)
u32 levels, bool dynamic)
: m_texture(std::move(texture)) : m_texture(std::move(texture))
, m_srv(std::move(srv)) , m_srv(std::move(srv))
, m_width(width) , m_width(width)
, m_height(height) , m_height(height)
, m_layers(layers)
, m_levels(levels)
, m_dynamic(dynamic) , m_dynamic(dynamic)
{ {
} }
@ -51,8 +48,6 @@ public:
void* GetHandle() const override { return m_srv.Get(); } void* GetHandle() const override { return m_srv.Get(); }
u32 GetWidth() const override { return m_width; } u32 GetWidth() const override { return m_width; }
u32 GetHeight() const override { return m_height; } u32 GetHeight() const override { return m_height; }
u32 GetLayers() const override { return m_layers; }
u32 GetLevels() const override { return m_levels; }
__fi ID3D11Texture2D* GetD3DTexture() const { return m_texture.Get(); } __fi ID3D11Texture2D* GetD3DTexture() const { return m_texture.Get(); }
__fi ID3D11ShaderResourceView* GetD3DSRV() const { return m_srv.Get(); } __fi ID3D11ShaderResourceView* GetD3DSRV() const { return m_srv.Get(); }
@ -64,8 +59,6 @@ private:
Microsoft::WRL::ComPtr<ID3D11ShaderResourceView> m_srv; Microsoft::WRL::ComPtr<ID3D11ShaderResourceView> m_srv;
u32 m_width; u32 m_width;
u32 m_height; u32 m_height;
u32 m_layers;
u32 m_levels;
bool m_dynamic; bool m_dynamic;
}; };
@ -135,10 +128,9 @@ bool D3D11HostDisplay::HasRenderSurface() const
return static_cast<bool>(m_swap_chain); return static_cast<bool>(m_swap_chain);
} }
std::unique_ptr<HostDisplayTexture> D3D11HostDisplay::CreateTexture(u32 width, u32 height, u32 layers, u32 levels, std::unique_ptr<HostDisplayTexture> D3D11HostDisplay::CreateTexture(u32 width, u32 height, const void* data, u32 data_stride, bool dynamic /* = false */)
const void* data, u32 data_stride, bool dynamic /* = false */)
{ {
const CD3D11_TEXTURE2D_DESC desc(DXGI_FORMAT_R8G8B8A8_UNORM, width, height, layers, levels, const CD3D11_TEXTURE2D_DESC desc(DXGI_FORMAT_R8G8B8A8_UNORM, width, height, 1u, 1u,
D3D11_BIND_SHADER_RESOURCE, dynamic ? D3D11_USAGE_DYNAMIC : D3D11_USAGE_DEFAULT, D3D11_BIND_SHADER_RESOURCE, dynamic ? D3D11_USAGE_DYNAMIC : D3D11_USAGE_DEFAULT,
dynamic ? D3D11_CPU_ACCESS_WRITE : 0, 1, 0, 0); dynamic ? D3D11_CPU_ACCESS_WRITE : 0, 1, 0, 0);
const D3D11_SUBRESOURCE_DATA srd{data, data_stride, data_stride * height}; const D3D11_SUBRESOURCE_DATA srd{data, data_stride, data_stride * height};
@ -154,11 +146,10 @@ std::unique_ptr<HostDisplayTexture> D3D11HostDisplay::CreateTexture(u32 width, u
if (FAILED(hr)) if (FAILED(hr))
return {}; return {};
return std::make_unique<D3D11HostDisplayTexture>(std::move(texture), std::move(srv), width, height, layers, levels, dynamic); return std::make_unique<D3D11HostDisplayTexture>(std::move(texture), std::move(srv), width, height, dynamic);
} }
void D3D11HostDisplay::UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, void D3D11HostDisplay::UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, const void* texture_data, u32 texture_data_stride)
const void* texture_data, u32 texture_data_stride)
{ {
D3D11HostDisplayTexture* d3d11_texture = static_cast<D3D11HostDisplayTexture*>(texture); D3D11HostDisplayTexture* d3d11_texture = static_cast<D3D11HostDisplayTexture*>(texture);
if (!d3d11_texture->IsDynamic()) if (!d3d11_texture->IsDynamic())

View File

@ -58,10 +58,8 @@ public:
void DestroyRenderSurface() override; void DestroyRenderSurface() override;
std::string GetDriverInfo() const override; std::string GetDriverInfo() const override;
std::unique_ptr<HostDisplayTexture> CreateTexture(u32 width, u32 height, u32 layers, u32 levels, std::unique_ptr<HostDisplayTexture> CreateTexture(u32 width, u32 height, const void* data, u32 data_stride, bool dynamic = false) override;
const void* data, u32 data_stride, bool dynamic = false) override; void UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, const void* texture_data, u32 texture_data_stride) override;
void UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, const void* texture_data,
u32 texture_data_stride) override;
bool GetHostRefreshRate(float* refresh_rate) override; bool GetHostRefreshRate(float* refresh_rate) override;

View File

@ -29,12 +29,10 @@
class OpenGLHostDisplayTexture : public HostDisplayTexture class OpenGLHostDisplayTexture : public HostDisplayTexture
{ {
public: public:
OpenGLHostDisplayTexture(GLuint texture, u32 width, u32 height, u32 layers, u32 levels) OpenGLHostDisplayTexture(GLuint texture, u32 width, u32 height)
: m_texture(texture) : m_texture(texture)
, m_width(width) , m_width(width)
, m_height(height) , m_height(height)
, m_layers(layers)
, m_levels(levels)
{ {
} }
~OpenGLHostDisplayTexture() override = default; ~OpenGLHostDisplayTexture() override = default;
@ -42,8 +40,6 @@ public:
void* GetHandle() const override { return reinterpret_cast<void*>(static_cast<uintptr_t>(m_texture)); } void* GetHandle() const override { return reinterpret_cast<void*>(static_cast<uintptr_t>(m_texture)); }
u32 GetWidth() const override { return m_width; } u32 GetWidth() const override { return m_width; }
u32 GetHeight() const override { return m_height; } u32 GetHeight() const override { return m_height; }
u32 GetLayers() const override { return m_layers; }
u32 GetLevels() const override { return m_levels; }
GLuint GetGLID() const { return m_texture; } GLuint GetGLID() const { return m_texture; }
@ -82,8 +78,7 @@ void* OpenGLHostDisplay::GetRenderSurface() const
return nullptr; return nullptr;
} }
std::unique_ptr<HostDisplayTexture> OpenGLHostDisplay::CreateTexture(u32 width, u32 height, u32 layers, u32 levels, std::unique_ptr<HostDisplayTexture> OpenGLHostDisplay::CreateTexture(u32 width, u32 height, const void* data, u32 data_stride, bool dynamic /* = false */)
const void* data, u32 data_stride, bool dynamic /* = false */)
{ {
// clear error // clear error
glGetError(); glGetError();
@ -105,11 +100,10 @@ std::unique_ptr<HostDisplayTexture> OpenGLHostDisplay::CreateTexture(u32 width,
return nullptr; return nullptr;
} }
return std::make_unique<OpenGLHostDisplayTexture>(id, width, height, layers, levels); return std::make_unique<OpenGLHostDisplayTexture>(id, width, height);
} }
void OpenGLHostDisplay::UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, void OpenGLHostDisplay::UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, const void* texture_data, u32 texture_data_stride)
const void* texture_data, u32 texture_data_stride)
{ {
OpenGLHostDisplayTexture* tex = static_cast<OpenGLHostDisplayTexture*>(texture); OpenGLHostDisplayTexture* tex = static_cast<OpenGLHostDisplayTexture*>(texture);

View File

@ -52,10 +52,8 @@ public:
void DestroyRenderSurface() override; void DestroyRenderSurface() override;
std::string GetDriverInfo() const override; std::string GetDriverInfo() const override;
std::unique_ptr<HostDisplayTexture> CreateTexture(u32 width, u32 height, u32 layers, u32 levels, const void* data, std::unique_ptr<HostDisplayTexture> CreateTexture(u32 width, u32 height, const void* data, u32 data_stride, bool dynamic) override;
u32 data_stride, bool dynamic) override; void UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, const void* texture_data, u32 texture_data_stride) override;
void UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, const void* texture_data,
u32 texture_data_stride) override;
void SetVSync(VsyncMode mode) override; void SetVSync(VsyncMode mode) override;

View File

@ -28,8 +28,6 @@ public:
void* GetHandle() const override { return const_cast<Vulkan::Texture*>(&m_texture); } void* GetHandle() const override { return const_cast<Vulkan::Texture*>(&m_texture); }
u32 GetWidth() const override { return m_texture.GetWidth(); } u32 GetWidth() const override { return m_texture.GetWidth(); }
u32 GetHeight() const override { return m_texture.GetHeight(); } u32 GetHeight() const override { return m_texture.GetHeight(); }
u32 GetLayers() const override { return m_texture.GetLayers(); }
u32 GetLevels() const override { return m_texture.GetLevels(); }
const Vulkan::Texture& GetTexture() const { return m_texture; } const Vulkan::Texture& GetTexture() const { return m_texture; }
Vulkan::Texture& GetTexture() { return m_texture; } Vulkan::Texture& GetTexture() { return m_texture; }
@ -178,19 +176,15 @@ static bool UploadBufferToTexture(Vulkan::Texture* texture, u32 width, u32 heigh
return true; return true;
} }
std::unique_ptr<HostDisplayTexture> VulkanHostDisplay::CreateTexture( std::unique_ptr<HostDisplayTexture> VulkanHostDisplay::CreateTexture(u32 width, u32 height, const void* data, u32 data_stride, bool dynamic /* = false */)
u32 width, u32 height, u32 layers, u32 levels, const void* data, u32 data_stride, bool dynamic /* = false */)
{ {
static constexpr VkFormat vk_format = VK_FORMAT_R8G8B8A8_UNORM; static constexpr VkFormat vk_format = VK_FORMAT_R8G8B8A8_UNORM;
static constexpr VkImageUsageFlags usage = static constexpr VkImageUsageFlags usage =
VK_IMAGE_USAGE_TRANSFER_SRC_BIT | VK_IMAGE_USAGE_TRANSFER_DST_BIT | VK_IMAGE_USAGE_SAMPLED_BIT; VK_IMAGE_USAGE_TRANSFER_SRC_BIT | VK_IMAGE_USAGE_TRANSFER_DST_BIT | VK_IMAGE_USAGE_SAMPLED_BIT;
Vulkan::Texture texture; Vulkan::Texture texture;
if (!texture.Create(width, height, levels, layers, vk_format, VK_SAMPLE_COUNT_1_BIT, if (!texture.Create(width, height, 1, 1, vk_format, VK_SAMPLE_COUNT_1_BIT, VK_IMAGE_VIEW_TYPE_2D, VK_IMAGE_TILING_OPTIMAL, usage))
(layers > 1) ? VK_IMAGE_VIEW_TYPE_2D_ARRAY : VK_IMAGE_VIEW_TYPE_2D, VK_IMAGE_TILING_OPTIMAL, usage))
{
return {}; return {};
}
texture.TransitionToLayout(g_vulkan_context->GetCurrentCommandBuffer(), VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL); texture.TransitionToLayout(g_vulkan_context->GetCurrentCommandBuffer(), VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL);

View File

@ -43,10 +43,8 @@ public:
void DestroyRenderSurface() override; void DestroyRenderSurface() override;
std::string GetDriverInfo() const override; std::string GetDriverInfo() const override;
std::unique_ptr<HostDisplayTexture> CreateTexture(u32 width, u32 height, u32 layers, u32 levels, std::unique_ptr<HostDisplayTexture> CreateTexture(u32 width, u32 height, const void* data, u32 data_stride, bool dynamic = false) override;
const void* data, u32 data_stride, bool dynamic = false) override; void UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, const void* texture_data, u32 texture_data_stride) override;
void UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, const void* texture_data,
u32 texture_data_stride) override;
void SetVSync(VsyncMode mode) override; void SetVSync(VsyncMode mode) override;

View File

@ -36,8 +36,6 @@ public:
virtual void* GetHandle() const = 0; virtual void* GetHandle() const = 0;
virtual u32 GetWidth() const = 0; virtual u32 GetWidth() const = 0;
virtual u32 GetHeight() const = 0; virtual u32 GetHeight() const = 0;
virtual u32 GetLayers() const = 0;
virtual u32 GetLevels() const = 0;
}; };
/// Interface to the frontend's renderer. /// Interface to the frontend's renderer.
@ -114,10 +112,8 @@ public:
virtual void ResizeRenderWindow(s32 new_window_width, s32 new_window_height, float new_window_scale) = 0; virtual void ResizeRenderWindow(s32 new_window_width, s32 new_window_height, float new_window_scale) = 0;
/// Creates an abstracted RGBA8 texture. If dynamic, the texture can be updated with UpdateTexture() below. /// Creates an abstracted RGBA8 texture. If dynamic, the texture can be updated with UpdateTexture() below.
virtual std::unique_ptr<HostDisplayTexture> CreateTexture(u32 width, u32 height, u32 layers, u32 levels, const void* data, virtual std::unique_ptr<HostDisplayTexture> CreateTexture(u32 width, u32 height, const void* data, u32 data_stride, bool dynamic = false) = 0;
u32 data_stride, bool dynamic = false) = 0; virtual void UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, const void* data, u32 data_stride) = 0;
virtual void UpdateTexture(HostDisplayTexture* texture, u32 x, u32 y, u32 width, u32 height, const void* data,
u32 data_stride) = 0;
/// Returns false if the window was completely occluded. If frame_skip is set, the frame won't be /// Returns false if the window was completely occluded. If frame_skip is set, the frame won't be
/// displayed, but the GPU command queue will still be flushed. /// displayed, but the GPU command queue will still be flushed.