From 98bfb77232c14288aedde716ced8b5eb6aecb02d Mon Sep 17 00:00:00 2001 From: chyyran Date: Thu, 12 Jan 2023 23:02:38 -0500 Subject: [PATCH] d3d11: fix unsoundness in hello triangle --- librashader-runtime-d3d11/src/hello_triangle.rs | 10 +++++----- librashader-runtime-d3d11/src/lib.rs | 1 + 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/librashader-runtime-d3d11/src/hello_triangle.rs b/librashader-runtime-d3d11/src/hello_triangle.rs index c2d943f..6a9cf12 100644 --- a/librashader-runtime-d3d11/src/hello_triangle.rs +++ b/librashader-runtime-d3d11/src/hello_triangle.rs @@ -128,11 +128,11 @@ where None, // no parent window None, // no menus instance, - Some(&mut sample as *mut _ as _), + Some(&sample as *const _ as _), ) }; - sample.bind_to_window(&hwnd)?; + sample.bind_to_window(&hwnd).unwrap(); unsafe { ShowWindow(hwnd, SW_SHOW) }; loop { @@ -285,10 +285,10 @@ pub mod d3d11_hello_triangle { let (rtv, backbuffer) = create_rtv(&self.device, &swapchain)?; let (depth_buffer, depth_stencil_view) = create_depth_buffer(&self.device)?; let (triangle_vbo, triangle_indices) = create_triangle_buffers(&self.device)?; - let triangle_uniforms = create_triangle_uniforms(&self.device)?; + let triangle_uniforms = create_triangle_uniforms(&self.device).unwrap(); - let vs_blob = compile_shader(VERTEX_SHADER, b"main\0", b"vs_5_0")?; - let ps_blob = compile_shader(PIXEL_SHADER, b"main\0", b"ps_5_0")?; + let vs_blob = compile_shader(VERTEX_SHADER, b"main\0", b"vs_5_0\0")?; + let ps_blob = compile_shader(PIXEL_SHADER, b"main\0", b"ps_5_0\0")?; let vs_compiled = unsafe { // SAFETY: slice as valid for as long as vs_blob is alive. diff --git a/librashader-runtime-d3d11/src/lib.rs b/librashader-runtime-d3d11/src/lib.rs index 3cd4d51..134812b 100644 --- a/librashader-runtime-d3d11/src/lib.rs +++ b/librashader-runtime-d3d11/src/lib.rs @@ -30,6 +30,7 @@ mod tests { fn triangle_d3d11() { let sample = hello_triangle::d3d11_hello_triangle::Sample::new( "../test/slang-shaders/bezel/Mega_Bezel/Presets/MBZ__0__SMOOTH-ADV.slangp", + // "../test/basic.slangp", Some(&FilterChainOptionsD3D11 { use_deferred_context: false, force_no_mipmaps: false,