d3d11: don't copy texture data, just copy the resource

This commit is contained in:
chyyran 2022-11-30 01:52:08 -05:00
parent 5088e1c55b
commit f044d0e91b
2 changed files with 24 additions and 43 deletions
librashader-runtime-d3d11/src

View file

@ -67,7 +67,6 @@ pub struct FilterCommon {
impl FilterChain {
fn create_constant_buffer(device: &ID3D11Device, size: u32) -> util::Result<ID3D11Buffer> {
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)
}

View file

@ -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(())
}
}