Skip to content

Commit

Permalink
extensions/khr: Add VK_KHR_sampler_ycbcr_conversion
Browse files Browse the repository at this point in the history
  • Loading branch information
spencercw committed Aug 14, 2023
1 parent f558761 commit 0b5f061
Show file tree
Hide file tree
Showing 3 changed files with 69 additions and 0 deletions.
1 change: 1 addition & 0 deletions Changelog.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- Added `VK_ANDROID_external_memory_android_hardware_buffer` device extension (#769)
- Added `VK_AMD_buffer_marker` device extension (#772)
- Added `VK_AMD_shader_info` device extension (#773)
- Added `VK_KHR_sampler_ycbcr_conversion` device extension (#785)

### Changed

Expand Down
2 changes: 2 additions & 0 deletions ash/src/extensions/khr/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ pub use self::present_wait::PresentWait;
pub use self::push_descriptor::PushDescriptor;
pub use self::ray_tracing_maintenance1::RayTracingMaintenance1;
pub use self::ray_tracing_pipeline::RayTracingPipeline;
pub use self::sampler_ycbcr_conversion::SamplerYcbcrConversion;
pub use self::surface::Surface;
pub use self::swapchain::Swapchain;
pub use self::synchronization2::Synchronization2;
Expand Down Expand Up @@ -67,6 +68,7 @@ mod present_wait;
mod push_descriptor;
mod ray_tracing_maintenance1;
mod ray_tracing_pipeline;
mod sampler_ycbcr_conversion;
mod surface;
mod swapchain;
mod synchronization2;
Expand Down
66 changes: 66 additions & 0 deletions ash/src/extensions/khr/sampler_ycbcr_conversion.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
use crate::prelude::*;
use crate::vk;
use crate::RawPtr;
use crate::{Device, Instance};
use std::ffi::CStr;
use std::mem;

/// <https://www.khronos.org/registry/vulkan/specs/1.3-extensions/man/html/VK_KHR_sampler_ycbcr_conversion.html>
#[derive(Clone)]
pub struct SamplerYcbcrConversion {
handle: vk::Device,
fp: vk::KhrSamplerYcbcrConversionFn,
}

impl SamplerYcbcrConversion {
pub fn new(instance: &Instance, device: &Device) -> Self {
let handle = device.handle();
let fp = vk::KhrSamplerYcbcrConversionFn::load(|name| unsafe {
mem::transmute(instance.get_device_proc_addr(handle, name.as_ptr()))
});
Self { handle, fp }
}

/// <https://www.khronos.org/registry/vulkan/specs/1.3-extensions/man/html/vkCreateSamplerYcbcrConversion.html>
#[inline]
pub unsafe fn create_sampler_ycbcr_conversion(
&self,
create_info: &vk::SamplerYcbcrConversionCreateInfo,
allocation_callbacks: Option<&vk::AllocationCallbacks>,
) -> VkResult<vk::SamplerYcbcrConversion> {
let mut ycbcr_conversion = mem::zeroed();
(self.fp.create_sampler_ycbcr_conversion_khr)(
self.handle,
create_info,
allocation_callbacks.as_raw_ptr(),
&mut ycbcr_conversion,
)
.result_with_success(ycbcr_conversion)
}

/// <https://www.khronos.org/registry/vulkan/specs/1.3-extensions/man/html/vkDestroySamplerYcbcrConversion.html>
#[inline]
pub unsafe fn destroy_sampler_ycbcr_conversion(
&self,
ycbcr_conversion: vk::SamplerYcbcrConversion,
allocation_callbacks: Option<&vk::AllocationCallbacks>,
) {
(self.fp.destroy_sampler_ycbcr_conversion_khr)(
self.handle,
ycbcr_conversion,
allocation_callbacks.as_raw_ptr(),
);
}

pub const NAME: &'static CStr = vk::KhrSamplerYcbcrConversionFn::NAME;

#[inline]
pub fn fp(&self) -> &vk::KhrSamplerYcbcrConversionFn {
&self.fp
}

#[inline]
pub fn device(&self) -> vk::Device {
self.handle
}
}

0 comments on commit 0b5f061

Please sign in to comment.