From f044d0e91bfaadd01be7eb7b04dca91f1076af92 Mon Sep 17 00:00:00 2001 From: chyyran Date: Wed, 30 Nov 2022 01:52:08 -0500 Subject: [PATCH] d3d11: don't copy texture data, just copy the resource --- librashader-runtime-d3d11/src/filter_chain.rs | 23 +--------- librashader-runtime-d3d11/src/framebuffer.rs | 44 ++++++++++--------- 2 files changed, 24 insertions(+), 43 deletions(-) diff --git a/librashader-runtime-d3d11/src/filter_chain.rs b/librashader-runtime-d3d11/src/filter_chain.rs index 581c585..e7aaf05 100644 --- a/librashader-runtime-d3d11/src/filter_chain.rs +++ b/librashader-runtime-d3d11/src/filter_chain.rs @@ -67,7 +67,6 @@ pub struct FilterCommon { impl FilterChain { fn create_constant_buffer(device: &ID3D11Device, size: u32) -> util::Result { - eprintln!("{size}"); unsafe { let buffer = device.CreateBuffer( &D3D11_BUFFER_DESC { @@ -313,27 +312,7 @@ impl FilterChain { fn push_history(&mut self, input: &DxImageView) -> util::Result<()> { if let Some(mut back) = self.history_framebuffers.pop_back() { - let resource = unsafe { - let mut resource = None; - input.handle.GetResource(&mut resource); - - // todo: make panic-free - resource.unwrap() - }; - - let format = unsafe { - let mut desc = Default::default(); - input.handle.GetDesc(&mut desc); - desc.Format - }; - - if back.size != input.size || (format != DXGI_FORMAT(0) && format != back.format) { - eprintln!("[history] resizing"); - back.init(input.size, ImageFormat::from(format))?; - } - - back.copy_from(&resource)?; - + back.copy_from(&input)?; self.history_framebuffers.push_front(back) } diff --git a/librashader-runtime-d3d11/src/framebuffer.rs b/librashader-runtime-d3d11/src/framebuffer.rs index ca21cde..21a3014 100644 --- a/librashader-runtime-d3d11/src/framebuffer.rs +++ b/librashader-runtime-d3d11/src/framebuffer.rs @@ -1,4 +1,5 @@ -use crate::texture::Texture; +use windows::core::Interface; +use crate::texture::{DxImageView, Texture}; use crate::util; use crate::util::d3d11_get_closest_format; use librashader_common::{ImageFormat, Size}; @@ -41,7 +42,6 @@ impl OwnedFramebuffer { | D3D11_FORMAT_SUPPORT_SHADER_SAMPLE.0 | D3D11_FORMAT_SUPPORT_RENDER_TARGET.0, ); - eprintln!("{format:?}"); let desc = default_desc(size, format); let texture = device.CreateTexture2D(&desc, None)?; @@ -105,6 +105,7 @@ impl OwnedFramebuffer { drop(texture) } self.format = format; + self.size = size; Ok(()) } @@ -150,26 +151,27 @@ impl OwnedFramebuffer { }) } - pub fn copy_from(&self, image: &ID3D11Resource) -> util::Result<()> { - unsafe { - self.context.CopySubresourceRegion( - &self.texture, - 0, - 0, - 0, - 0, - image, - 0, - Some(&D3D11_BOX { - left: 0, - top: 0, - front: 0, - right: self.size.width, - bottom: self.size.height, - back: 1, - }), - ) + pub fn copy_from(&mut self, image: &DxImageView) -> util::Result<()> { + let resource: ID3D11Texture2D = unsafe { + let mut resource = None; + image.handle.GetResource(&mut resource); + + // todo: make panic-free + resource.unwrap().cast()? + }; + + let format = unsafe { + let mut desc = Default::default(); + resource.GetDesc(&mut desc); + desc.Format + }; + + if self.size != image.size || format != self.format { + eprintln!("[history] resizing"); + self.init(image.size, ImageFormat::from(format))?; } + + self.texture = resource.clone(); Ok(()) } }