From abadfb3ee1f10a25b11f5f8a9827c72e017ad8c7 Mon Sep 17 00:00:00 2001 From: chyyran Date: Sun, 12 Feb 2023 03:11:07 -0500 Subject: [PATCH] d3d12: use dxc to compile mipmap shader removes fxc dependency completely. Also slim down windows-rs features where only needed for testing. --- librashader-runtime-d3d11/Cargo.toml | 13 +++++ librashader-runtime-d3d11/src/lib.rs | 3 +- librashader-runtime-d3d12/Cargo.toml | 16 +++++- .../src/graphics_pipeline.rs | 6 +-- librashader-runtime-d3d12/src/lib.rs | 2 +- librashader-runtime-d3d12/src/mipmap.rs | 9 +++- librashader-runtime-d3d12/src/util.rs | 50 +++---------------- 7 files changed, 47 insertions(+), 52 deletions(-) diff --git a/librashader-runtime-d3d11/Cargo.toml b/librashader-runtime-d3d11/Cargo.toml index e53f34c..3d0a77f 100644 --- a/librashader-runtime-d3d11/Cargo.toml +++ b/librashader-runtime-d3d11/Cargo.toml @@ -27,6 +27,19 @@ array-concat = "0.5.2" [target.'cfg(windows)'.dependencies.windows] version = "0.44.0" +features = [ + "Win32_Foundation", + "Win32_Graphics_Dxgi_Common", + "Win32_Graphics_Direct3D", + "Win32_Graphics_Direct3D11", + "Win32_Graphics_Direct3D_Fxc", + "Win32_System_Threading", + "Win32_System_WindowsProgramming", + "Win32_Security", +] + +[target.'cfg(windows)'.dev-dependencies.windows] +version = "0.44.0" features = [ "Win32_Foundation", "Win32_Graphics_Dxgi_Common", diff --git a/librashader-runtime-d3d11/src/lib.rs b/librashader-runtime-d3d11/src/lib.rs index cca8924..d5fdf40 100644 --- a/librashader-runtime-d3d11/src/lib.rs +++ b/librashader-runtime-d3d11/src/lib.rs @@ -30,7 +30,6 @@ mod tests { use super::*; use crate::options::FilterChainOptionsD3D11; use librashader_runtime::image::{Image, UVDirection}; - use std::env; // "../test/slang-shaders/scalefx/scalefx-9x.slangp", // "../test/slang-shaders/bezel/koko-aio/monitor-bloom.slangp", @@ -48,7 +47,7 @@ mod tests { const IMAGE_PATH: &str = "../triangle.png"; #[test] fn triangle_d3d11_args() { - let mut args = env::args(); + let mut args = std::env::args(); let _ = args.next(); let _ = args.next(); let filter = args.next(); diff --git a/librashader-runtime-d3d12/Cargo.toml b/librashader-runtime-d3d12/Cargo.toml index 733da98..feff9fd 100644 --- a/librashader-runtime-d3d12/Cargo.toml +++ b/librashader-runtime-d3d12/Cargo.toml @@ -32,6 +32,18 @@ rayon = "1.6.1" [target.'cfg(windows)'.dependencies.windows] version = "0.44.0" +features = [ + "Win32_Foundation", + "Win32_Graphics_Dxgi_Common", + "Win32_Graphics_Direct3D", + "Win32_Graphics_Direct3D12", + "Win32_Graphics_Direct3D_Dxc", + "Win32_System_Threading", + "Win32_System_WindowsProgramming", + "Win32_Security", +] + +[target.'cfg(windows)'.dev-dependencies.windows] features = [ "Win32_Foundation", "Win32_Graphics_Dxgi_Common", @@ -43,8 +55,10 @@ features = [ "Win32_Security", "Win32_System_LibraryLoader", "Win32_System_Threading", - "Win32_System_WindowsProgramming", "Win32_UI_WindowsAndMessaging", + "Win32_System_Threading", + "Win32_System_WindowsProgramming", ] [dev-dependencies] gfx-maths = "0.2.8" + diff --git a/librashader-runtime-d3d12/src/graphics_pipeline.rs b/librashader-runtime-d3d12/src/graphics_pipeline.rs index efb0bfa..6f0a762 100644 --- a/librashader-runtime-d3d12/src/graphics_pipeline.rs +++ b/librashader-runtime-d3d12/src/graphics_pipeline.rs @@ -1,3 +1,4 @@ +use widestring::u16cstr; use crate::error::assume_d3d12_init; use crate::error::FilterChainError::Direct3DOperationError; use crate::quad_render::DrawQuad; @@ -5,7 +6,6 @@ use crate::{error, util}; use librashader_reflect::back::cross::CrossHlslContext; use librashader_reflect::back::dxil::DxilObject; use librashader_reflect::back::ShaderCompilerOutput; -use librashader_reflect::reflect::semantics::BindingStage; use windows::Win32::Foundation::BOOL; use windows::Win32::Graphics::Direct3D::Dxc::{ CLSID_DxcLibrary, DxcCreateInstance, IDxcBlob, IDxcCompiler, IDxcUtils, IDxcValidator, DXC_CP, @@ -308,12 +308,12 @@ impl D3D12GraphicsPipeline { render_format: DXGI_FORMAT, ) -> error::Result { let vertex_dxil = - util::dxc_compile_shader(library, dxc, &shader_assembly.vertex, BindingStage::VERTEX)?; + util::dxc_compile_shader(library, dxc, &shader_assembly.vertex, u16cstr!("vs_6_0"))?; let fragment_dxil = util::dxc_compile_shader( library, dxc, &shader_assembly.fragment, - BindingStage::FRAGMENT, + u16cstr!("ps_6_0") )?; Self::new_from_blobs( diff --git a/librashader-runtime-d3d12/src/lib.rs b/librashader-runtime-d3d12/src/lib.rs index 0031020..bc09170 100644 --- a/librashader-runtime-d3d12/src/lib.rs +++ b/librashader-runtime-d3d12/src/lib.rs @@ -36,7 +36,7 @@ mod tests { // "../test/slang-shaders/crt/crt-lottes.slangp", // "../test/basic.slangp", // "../test/slang-shaders/handheld/console-border/gbc-lcd-grid-v2.slangp", - "../test/slang-shaders/bezel/Mega_Bezel/Presets/MBZ__0__SMOOTH-ADV-GLASS.slangp", + "../test/slang-shaders/bezel/Mega_Bezel/Presets/MBZ__0__SMOOTH-ADV.slangp", // "../test/slang-shaders/test/feedback.slangp", // "../test/slang-shaders/test/history.slangp", // "../test/slang-shaders/crt/crt-royale.slangp", diff --git a/librashader-runtime-d3d12/src/mipmap.rs b/librashader-runtime-d3d12/src/mipmap.rs index c77a2f4..4462d09 100644 --- a/librashader-runtime-d3d12/src/mipmap.rs +++ b/librashader-runtime-d3d12/src/mipmap.rs @@ -1,11 +1,12 @@ use crate::descriptor_heap::{D3D12DescriptorHeap, D3D12DescriptorHeapSlot, ResourceWorkHeap}; -use crate::util::fxc_compile_shader; +use crate::util::dxc_compile_shader; use crate::{error, util}; use bytemuck::{Pod, Zeroable}; use librashader_common::Size; use librashader_runtime::scaling::MipmapSize; use std::mem::ManuallyDrop; use std::ops::Deref; +use widestring::u16cstr; use windows::Win32::Graphics::Direct3D12::{ ID3D12DescriptorHeap, ID3D12Device, ID3D12GraphicsCommandList, ID3D12PipelineState, ID3D12Resource, ID3D12RootSignature, D3D12_COMPUTE_PIPELINE_STATE_DESC, @@ -16,6 +17,7 @@ use windows::Win32::Graphics::Direct3D12::{ D3D12_SRV_DIMENSION_TEXTURE2D, D3D12_TEX2D_SRV, D3D12_TEX2D_UAV, D3D12_UAV_DIMENSION_TEXTURE2D, D3D12_UNORDERED_ACCESS_VIEW_DESC, D3D12_UNORDERED_ACCESS_VIEW_DESC_0, }; +use windows::Win32::Graphics::Direct3D::Dxc::{CLSID_DxcCompiler, CLSID_DxcLibrary, DxcCreateInstance}; use windows::Win32::Graphics::Dxgi::Common::DXGI_FORMAT; static GENERATE_MIPS_SRC: &[u8] = b" @@ -124,7 +126,10 @@ impl<'a> MipmapGenContext<'a> { impl D3D12MipmapGen { pub fn new(device: &ID3D12Device, own_heaps: bool) -> error::Result { unsafe { - let blob = fxc_compile_shader(GENERATE_MIPS_SRC, b"main\0", b"cs_5_1\0")?; + let library = DxcCreateInstance(&CLSID_DxcLibrary)?; + let compiler = DxcCreateInstance(&CLSID_DxcCompiler)?; + + let blob = dxc_compile_shader(&library, &compiler, GENERATE_MIPS_SRC, u16cstr!("cs_6_0"))?; let blob = std::slice::from_raw_parts(blob.GetBufferPointer().cast(), blob.GetBufferSize()); let root_signature: ID3D12RootSignature = device.CreateRootSignature(0, blob)?; diff --git a/librashader-runtime-d3d12/src/util.rs b/librashader-runtime-d3d12/src/util.rs index 13f6039..8a3c90d 100644 --- a/librashader-runtime-d3d12/src/util.rs +++ b/librashader-runtime-d3d12/src/util.rs @@ -1,19 +1,15 @@ use crate::error; use crate::error::assume_d3d12_init; -use librashader_reflect::reflect::semantics::BindingStage; use std::mem::ManuallyDrop; use std::u64; -use widestring::u16cstr; -use windows::core::{PCSTR, PCWSTR}; +use widestring::{u16cstr, U16CStr}; +use windows::core::PCWSTR; use windows::Win32::Graphics::Direct3D::Dxc::{ DxcValidatorFlags_InPlaceEdit, IDxcBlob, IDxcCompiler, IDxcUtils, IDxcValidator, DXC_CP, DXC_CP_UTF8, }; -use windows::Win32::Graphics::Direct3D::Fxc::{ - D3DCompile, D3DCOMPILE_DEBUG, D3DCOMPILE_OPTIMIZATION_LEVEL3, D3DCOMPILE_SKIP_OPTIMIZATION, -}; -use windows::Win32::Graphics::Direct3D::ID3DBlob; + use windows::Win32::Graphics::Direct3D12::{ ID3D12Device, ID3D12GraphicsCommandList, ID3D12Resource, D3D12_FEATURE_DATA_FORMAT_SUPPORT, D3D12_FEATURE_FORMAT_SUPPORT, D3D12_MEMCPY_DEST, D3D12_PLACED_SUBRESOURCE_FOOTPRINT, @@ -132,54 +128,22 @@ pub fn d3d12_get_closest_format( DXGI_FORMAT_UNKNOWN } -pub fn fxc_compile_shader(source: &[u8], entry: &[u8], version: &[u8]) -> error::Result { - unsafe { - let mut blob = None; - D3DCompile( - source.as_ptr().cast(), - source.len(), - None, - None, - None, - PCSTR(entry.as_ptr()), - PCSTR(version.as_ptr()), - if cfg!(feature = "debug-shader") { - D3DCOMPILE_DEBUG | D3DCOMPILE_SKIP_OPTIMIZATION - } else { - D3DCOMPILE_OPTIMIZATION_LEVEL3 - }, - 0, - &mut blob, - None, - )?; - - assume_d3d12_init!(blob, "D3DCompile"); - Ok(blob) - } -} - pub fn dxc_compile_shader( library: &IDxcUtils, compiler: &IDxcCompiler, - source: &String, - profile: BindingStage, + source: impl AsRef<[u8]>, + profile: &U16CStr, ) -> error::Result { let include = unsafe { library.CreateDefaultIncludeHandler()? }; - + let source = source.as_ref(); let blob = unsafe { library.CreateBlobFromPinned( source.as_ptr().cast(), - source.as_bytes().len() as u32, + source.len() as u32, DXC_CP_UTF8, )? }; - let profile = if profile == BindingStage::FRAGMENT { - u16cstr!("ps_6_0") - } else { - u16cstr!("vs_6_0") - }; - unsafe { let result = compiler.Compile( &blob,