ash/extensions/khr/
ray_tracing_pipeline.rs1use crate::prelude::*;
4use crate::vk;
5use crate::RawPtr;
6use alloc::vec::Vec;
7
8impl crate::khr::ray_tracing_pipeline::Device {
9 #[inline]
11 pub unsafe fn cmd_trace_rays(
12 &self,
13 command_buffer: vk::CommandBuffer,
14 raygen_shader_binding_tables: &vk::StridedDeviceAddressRegionKHR,
15 miss_shader_binding_tables: &vk::StridedDeviceAddressRegionKHR,
16 hit_shader_binding_tables: &vk::StridedDeviceAddressRegionKHR,
17 callable_shader_binding_tables: &vk::StridedDeviceAddressRegionKHR,
18 width: u32,
19 height: u32,
20 depth: u32,
21 ) {
22 (self.fp.cmd_trace_rays_khr)(
23 command_buffer,
24 raygen_shader_binding_tables,
25 miss_shader_binding_tables,
26 hit_shader_binding_tables,
27 callable_shader_binding_tables,
28 width,
29 height,
30 depth,
31 );
32 }
33
34 #[inline]
40 pub unsafe fn create_ray_tracing_pipelines(
41 &self,
42 deferred_operation: vk::DeferredOperationKHR,
43 pipeline_cache: vk::PipelineCache,
44 create_infos: &[vk::RayTracingPipelineCreateInfoKHR<'_>],
45 allocation_callbacks: Option<&vk::AllocationCallbacks<'_>>,
46 ) -> Result<Vec<vk::Pipeline>, (Vec<vk::Pipeline>, vk::Result)> {
47 let mut pipelines = Vec::with_capacity(create_infos.len());
48 let err_code = (self.fp.create_ray_tracing_pipelines_khr)(
49 self.handle,
50 deferred_operation,
51 pipeline_cache,
52 create_infos.len() as u32,
53 create_infos.as_ptr(),
54 allocation_callbacks.as_raw_ptr(),
55 pipelines.as_mut_ptr(),
56 );
57 pipelines.set_len(create_infos.len());
58 match err_code {
59 vk::Result::SUCCESS => Ok(pipelines),
60 _ => Err((pipelines, err_code)),
61 }
62 }
63
64 #[inline]
66 pub unsafe fn get_ray_tracing_shader_group_handles(
67 &self,
68 pipeline: vk::Pipeline,
69 first_group: u32,
70 group_count: u32,
71 data_size: usize,
72 ) -> VkResult<Vec<u8>> {
73 let mut data = Vec::<u8>::with_capacity(data_size);
74 (self.fp.get_ray_tracing_shader_group_handles_khr)(
75 self.handle,
76 pipeline,
77 first_group,
78 group_count,
79 data_size,
80 data.as_mut_ptr().cast(),
81 )
82 .set_vec_len_on_success(data, data_size)
83 }
84
85 #[inline]
87 pub unsafe fn get_ray_tracing_capture_replay_shader_group_handles(
88 &self,
89 pipeline: vk::Pipeline,
90 first_group: u32,
91 group_count: u32,
92 data_size: usize,
93 ) -> VkResult<Vec<u8>> {
94 let mut data = Vec::<u8>::with_capacity(data_size);
95 (self
96 .fp
97 .get_ray_tracing_capture_replay_shader_group_handles_khr)(
98 self.handle,
99 pipeline,
100 first_group,
101 group_count,
102 data_size,
103 data.as_mut_ptr().cast(),
104 )
105 .set_vec_len_on_success(data, data_size)
106 }
107
108 #[inline]
112 pub unsafe fn cmd_trace_rays_indirect(
113 &self,
114 command_buffer: vk::CommandBuffer,
115 raygen_shader_binding_table: &vk::StridedDeviceAddressRegionKHR,
116 miss_shader_binding_table: &vk::StridedDeviceAddressRegionKHR,
117 hit_shader_binding_table: &vk::StridedDeviceAddressRegionKHR,
118 callable_shader_binding_table: &vk::StridedDeviceAddressRegionKHR,
119 indirect_device_address: vk::DeviceAddress,
120 ) {
121 (self.fp.cmd_trace_rays_indirect_khr)(
122 command_buffer,
123 raygen_shader_binding_table,
124 miss_shader_binding_table,
125 hit_shader_binding_table,
126 callable_shader_binding_table,
127 indirect_device_address,
128 );
129 }
130
131 #[inline]
133 pub unsafe fn get_ray_tracing_shader_group_stack_size(
134 &self,
135 pipeline: vk::Pipeline,
136 group: u32,
137 group_shader: vk::ShaderGroupShaderKHR,
138 ) -> vk::DeviceSize {
139 (self.fp.get_ray_tracing_shader_group_stack_size_khr)(
140 self.handle,
141 pipeline,
142 group,
143 group_shader,
144 )
145 }
146
147 #[inline]
149 pub unsafe fn cmd_set_ray_tracing_pipeline_stack_size(
150 &self,
151 command_buffer: vk::CommandBuffer,
152 pipeline_stack_size: u32,
153 ) {
154 (self.fp.cmd_set_ray_tracing_pipeline_stack_size_khr)(command_buffer, pipeline_stack_size);
155 }
156}