mirror of
https://github.com/italicsjenga/portability.git
synced 2024-11-30 10:51:32 +11:00
Merge #35
35: Missing stuff to get triangle CTS tests running r=msiglreith a=kvark
This commit is contained in:
commit
c692153a2d
|
@ -13,6 +13,7 @@ vulkan = ["gfx-backend-vulkan"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
lazy_static = "1.0"
|
lazy_static = "1.0"
|
||||||
|
log = "0.4"
|
||||||
|
|
||||||
[dependencies.gfx-hal]
|
[dependencies.gfx-hal]
|
||||||
git = "https://github.com/gfx-rs/gfx"
|
git = "https://github.com/gfx-rs/gfx"
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
use hal::{buffer, command, error, format, image, memory, pass, pso, window};
|
use hal::{buffer, command, error, format, image, memory, pass, pso, window};
|
||||||
|
use hal::device::Extent;
|
||||||
use hal::{PatchSize, Primitive};
|
use hal::{PatchSize, Primitive};
|
||||||
|
|
||||||
use std::mem;
|
use std::mem;
|
||||||
|
@ -116,6 +117,15 @@ fn map_swizzle_component(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn map_subresource_layers(subresource: VkImageSubresourceLayers) -> image::SubresourceLayers {
|
||||||
|
image::SubresourceLayers {
|
||||||
|
aspects: map_aspect(subresource.aspectMask),
|
||||||
|
level: subresource.mipLevel as _,
|
||||||
|
layers: subresource.baseArrayLayer as _
|
||||||
|
..(subresource.baseArrayLayer + subresource.layerCount) as _,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn map_subresource_range(subresource: VkImageSubresourceRange) -> image::SubresourceRange {
|
pub fn map_subresource_range(subresource: VkImageSubresourceRange) -> image::SubresourceRange {
|
||||||
image::SubresourceRange {
|
image::SubresourceRange {
|
||||||
aspects: map_aspect(subresource.aspectMask),
|
aspects: map_aspect(subresource.aspectMask),
|
||||||
|
@ -236,6 +246,52 @@ pub fn map_image_usage(usage: VkImageUsageFlags) -> image::Usage {
|
||||||
flags
|
flags
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn map_image_access(access: VkAccessFlags) -> image::Access {
|
||||||
|
let mut mask = image::Access::empty();
|
||||||
|
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_INPUT_ATTACHMENT_READ_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::INPUT_ATTACHMENT_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_SHADER_READ_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::SHADER_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_SHADER_WRITE_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::SHADER_WRITE;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_COLOR_ATTACHMENT_READ_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::COLOR_ATTACHMENT_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::COLOR_ATTACHMENT_WRITE;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::DEPTH_STENCIL_ATTACHMENT_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::DEPTH_STENCIL_ATTACHMENT_WRITE;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_TRANSFER_READ_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::TRANSFER_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_TRANSFER_WRITE_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::TRANSFER_WRITE;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_HOST_READ_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::HOST_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_HOST_WRITE_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::HOST_WRITE;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_MEMORY_READ_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::MEMORY_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_MEMORY_WRITE_BIT as u32 != 0 {
|
||||||
|
mask |= image::Access::MEMORY_WRITE;
|
||||||
|
}
|
||||||
|
|
||||||
|
mask
|
||||||
|
}
|
||||||
|
|
||||||
pub fn map_buffer_usage(usage: VkBufferUsageFlags) -> buffer::Usage {
|
pub fn map_buffer_usage(usage: VkBufferUsageFlags) -> buffer::Usage {
|
||||||
let mut flags = buffer::Usage::empty();
|
let mut flags = buffer::Usage::empty();
|
||||||
|
|
||||||
|
@ -270,6 +326,46 @@ pub fn map_buffer_usage(usage: VkBufferUsageFlags) -> buffer::Usage {
|
||||||
flags
|
flags
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn map_buffer_access(access: VkAccessFlags) -> buffer::Access {
|
||||||
|
let mut mask = buffer::Access::empty();
|
||||||
|
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_VERTEX_ATTRIBUTE_READ_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::VERTEX_BUFFER_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_UNIFORM_READ_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::CONSTANT_BUFFER_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_INDIRECT_COMMAND_READ_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::INDIRECT_COMMAND_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_SHADER_READ_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::SHADER_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_SHADER_WRITE_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::SHADER_WRITE;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_TRANSFER_READ_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::TRANSFER_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_TRANSFER_WRITE_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::TRANSFER_WRITE;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_HOST_READ_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::HOST_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_HOST_WRITE_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::HOST_WRITE;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_MEMORY_READ_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::MEMORY_READ;
|
||||||
|
}
|
||||||
|
if access & VkAccessFlagBits::VK_ACCESS_MEMORY_WRITE_BIT as u32 != 0 {
|
||||||
|
mask |= buffer::Access::MEMORY_WRITE;
|
||||||
|
}
|
||||||
|
|
||||||
|
mask
|
||||||
|
}
|
||||||
|
|
||||||
pub fn memory_properties_from_hal(properties: memory::Properties) -> VkMemoryPropertyFlags {
|
pub fn memory_properties_from_hal(properties: memory::Properties) -> VkMemoryPropertyFlags {
|
||||||
let mut flags = 0;
|
let mut flags = 0;
|
||||||
|
|
||||||
|
@ -350,8 +446,9 @@ pub fn map_pipeline_stage_flags(stages: VkPipelineStageFlags) -> pso::PipelineSt
|
||||||
// HAL flags have the same numeric representation as Vulkan flags
|
// HAL flags have the same numeric representation as Vulkan flags
|
||||||
unsafe { mem::transmute(stages) }
|
unsafe { mem::transmute(stages) }
|
||||||
} else {
|
} else {
|
||||||
// GRAPHICS and ALL missing
|
// GRAPHICS and ALL are missing
|
||||||
unimplemented!("Unsupported pipelinee stage flags: {:?}", stages)
|
warn!("Unsupported pipeline stage flags: {:?}", stages);
|
||||||
|
pso::PipelineStage::all()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -386,52 +483,6 @@ pub fn map_attachment_store_op(op: VkAttachmentStoreOp) -> pass::AttachmentStore
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn map_image_acces(access: VkAccessFlags) -> image::Access {
|
|
||||||
let mut mask = image::Access::empty();
|
|
||||||
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_INPUT_ATTACHMENT_READ_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::INPUT_ATTACHMENT_READ;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_SHADER_READ_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::SHADER_READ;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_SHADER_WRITE_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::SHADER_WRITE;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_COLOR_ATTACHMENT_READ_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::COLOR_ATTACHMENT_READ;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::COLOR_ATTACHMENT_WRITE;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::DEPTH_STENCIL_ATTACHMENT_READ;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::DEPTH_STENCIL_ATTACHMENT_WRITE;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_TRANSFER_READ_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::TRANSFER_READ;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_TRANSFER_WRITE_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::TRANSFER_WRITE;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_HOST_READ_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::HOST_READ;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_HOST_WRITE_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::HOST_WRITE;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_MEMORY_READ_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::MEMORY_READ;
|
|
||||||
}
|
|
||||||
if access & VkAccessFlagBits::VK_ACCESS_MEMORY_WRITE_BIT as u32 != 0 {
|
|
||||||
mask |= image::Access::MEMORY_WRITE;
|
|
||||||
}
|
|
||||||
|
|
||||||
mask
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn map_subpass_contents(contents: VkSubpassContents) -> command::SubpassContents {
|
pub fn map_subpass_contents(contents: VkSubpassContents) -> command::SubpassContents {
|
||||||
match contents {
|
match contents {
|
||||||
VkSubpassContents::VK_SUBPASS_CONTENTS_INLINE => command::SubpassContents::Inline,
|
VkSubpassContents::VK_SUBPASS_CONTENTS_INLINE => command::SubpassContents::Inline,
|
||||||
|
@ -538,8 +589,24 @@ pub fn map_wrap_mode(mode: VkSamplerAddressMode) -> image::WrapMode {
|
||||||
VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE => image::WrapMode::Clamp,
|
VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE => image::WrapMode::Clamp,
|
||||||
VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER => image::WrapMode::Border,
|
VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER => image::WrapMode::Border,
|
||||||
other => {
|
other => {
|
||||||
//warn!("Non-covered sampler address mode: {:?}", mode);
|
warn!("Non-covered sampler address mode: {:?}", mode);
|
||||||
image::WrapMode::Clamp
|
image::WrapMode::Clamp
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn map_offset(extent: VkOffset3D) -> command::Offset {
|
||||||
|
command::Offset {
|
||||||
|
x: extent.x,
|
||||||
|
y: extent.y,
|
||||||
|
z: extent.z,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn map_extent(extent: VkExtent3D) -> Extent {
|
||||||
|
Extent {
|
||||||
|
width: extent.width,
|
||||||
|
height: extent.height,
|
||||||
|
depth: extent.depth,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
use hal::{pass, pso, queue};
|
use hal::{command as com, memory, pass, pso, queue};
|
||||||
use hal::{
|
use hal::{
|
||||||
Backend, DescriptorPool, Device, Instance, PhysicalDevice, QueueFamily,
|
Backend, DescriptorPool, Device, Instance, PhysicalDevice, QueueFamily,
|
||||||
Surface, Swapchain as HalSwapchain, FrameSync,
|
Surface, Swapchain as HalSwapchain, FrameSync,
|
||||||
};
|
};
|
||||||
use hal::device::WaitFor;
|
use hal::device::WaitFor;
|
||||||
use hal::pool::RawCommandPool;
|
use hal::pool::RawCommandPool;
|
||||||
use hal::command::{ClearValueRaw, RawCommandBuffer, RawLevel, Rect, Viewport};
|
use hal::command::RawCommandBuffer;
|
||||||
use hal::queue::RawCommandQueue;
|
use hal::queue::RawCommandQueue;
|
||||||
|
|
||||||
use std::ffi::{CStr, CString};
|
use std::ffi::{CStr, CString};
|
||||||
|
@ -30,13 +30,13 @@ pub type PFN_vkEnumeratePhysicalDevices = ::std::option::Option<unsafe extern "C
|
||||||
) -> VkResult>;
|
) -> VkResult>;
|
||||||
|
|
||||||
macro_rules! proc_addr {
|
macro_rules! proc_addr {
|
||||||
($name:expr, $($vk:ident, $pfn_vk:ident => $gfx:expr),*) => (
|
($name:expr, $($vk:ident, $pfn_vk:ident => $gfx:expr,)*) => (
|
||||||
match $name {
|
match $name {
|
||||||
$(
|
$(
|
||||||
stringify!($vk) => unsafe {
|
stringify!($vk) => unsafe {
|
||||||
mem::transmute::<$pfn_vk, _>(Some(*&$gfx))
|
mem::transmute::<$pfn_vk, _>(Some(*&$gfx))
|
||||||
}
|
},
|
||||||
),*
|
)*
|
||||||
_ => None
|
_ => None
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
@ -251,7 +251,7 @@ pub extern "C" fn gfxGetInstanceProcAddr(
|
||||||
vkGetPhysicalDeviceSurfaceSupportKHR, PFN_vkGetPhysicalDeviceSurfaceSupportKHR => gfxGetPhysicalDeviceSurfaceSupportKHR,
|
vkGetPhysicalDeviceSurfaceSupportKHR, PFN_vkGetPhysicalDeviceSurfaceSupportKHR => gfxGetPhysicalDeviceSurfaceSupportKHR,
|
||||||
vkGetPhysicalDeviceSurfaceCapabilitiesKHR, PFN_vkGetPhysicalDeviceSurfaceCapabilitiesKHR => gfxGetPhysicalDeviceSurfaceCapabilitiesKHR,
|
vkGetPhysicalDeviceSurfaceCapabilitiesKHR, PFN_vkGetPhysicalDeviceSurfaceCapabilitiesKHR => gfxGetPhysicalDeviceSurfaceCapabilitiesKHR,
|
||||||
vkGetPhysicalDeviceSurfaceFormatsKHR, PFN_vkGetPhysicalDeviceSurfaceFormatsKHR => gfxGetPhysicalDeviceSurfaceFormatsKHR,
|
vkGetPhysicalDeviceSurfaceFormatsKHR, PFN_vkGetPhysicalDeviceSurfaceFormatsKHR => gfxGetPhysicalDeviceSurfaceFormatsKHR,
|
||||||
vkGetPhysicalDeviceSurfacePresentModesKHR, PFN_vkGetPhysicalDeviceSurfacePresentModesKHR => gfxGetPhysicalDeviceSurfacePresentModesKHR
|
vkGetPhysicalDeviceSurfacePresentModesKHR, PFN_vkGetPhysicalDeviceSurfacePresentModesKHR => gfxGetPhysicalDeviceSurfacePresentModesKHR,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -272,8 +272,63 @@ pub extern "C" fn gfxGetDeviceProcAddr(
|
||||||
vkGetSwapchainImagesKHR, PFN_vkGetSwapchainImagesKHR => gfxGetSwapchainImagesKHR,
|
vkGetSwapchainImagesKHR, PFN_vkGetSwapchainImagesKHR => gfxGetSwapchainImagesKHR,
|
||||||
vkAcquireNextImageKHR, PFN_vkAcquireNextImageKHR => gfxAcquireNextImageKHR,
|
vkAcquireNextImageKHR, PFN_vkAcquireNextImageKHR => gfxAcquireNextImageKHR,
|
||||||
vkQueuePresentKHR, PFN_vkQueuePresentKHR => gfxQueuePresentKHR,
|
vkQueuePresentKHR, PFN_vkQueuePresentKHR => gfxQueuePresentKHR,
|
||||||
|
|
||||||
vkCreateSampler, PFN_vkCreateSampler => gfxCreateSampler,
|
vkCreateSampler, PFN_vkCreateSampler => gfxCreateSampler,
|
||||||
vkDestroySampler, PFN_vkDestroySampler => gfxDestroySampler
|
vkDestroySampler, PFN_vkDestroySampler => gfxDestroySampler,
|
||||||
|
vkCreateShaderModule, PFN_vkCreateShaderModule => gfxCreateShaderModule,
|
||||||
|
vkDestroyShaderModule, PFN_vkDestroyShaderModule => gfxDestroyShaderModule,
|
||||||
|
vkGetDeviceQueue, PFN_vkGetDeviceQueue => gfxGetDeviceQueue,
|
||||||
|
|
||||||
|
vkAllocateMemory, PFN_vkAllocateMemory => gfxAllocateMemory,
|
||||||
|
vkFreeMemory, PFN_vkFreeMemory => gfxFreeMemory,
|
||||||
|
vkMapMemory, PFN_vkMapMemory => gfxMapMemory,
|
||||||
|
vkUnmapMemory, PFN_vkUnmapMemory => gfxUnmapMemory,
|
||||||
|
vkFlushMappedMemoryRanges, PFN_vkFlushMappedMemoryRanges => gfxFlushMappedMemoryRanges,
|
||||||
|
vkInvalidateMappedMemoryRanges, PFN_vkInvalidateMappedMemoryRanges => gfxInvalidateMappedMemoryRanges,
|
||||||
|
|
||||||
|
vkCreateBuffer, PFN_vkCreateBuffer => gfxCreateBuffer,
|
||||||
|
vkDestroyBuffer, PFN_vkDestroyBuffer => gfxDestroyBuffer,
|
||||||
|
vkGetBufferMemoryRequirements, PFN_vkGetBufferMemoryRequirements => gfxGetBufferMemoryRequirements,
|
||||||
|
vkBindBufferMemory, PFN_vkBindBufferMemory => gfxBindBufferMemory,
|
||||||
|
|
||||||
|
vkCreateImage, PFN_vkCreateImage => gfxCreateImage,
|
||||||
|
vkDestroyImage, PFN_vkDestroyImage => gfxDestroyImage,
|
||||||
|
vkGetImageMemoryRequirements, PFN_vkGetImageMemoryRequirements => gfxGetImageMemoryRequirements,
|
||||||
|
vkBindImageMemory, PFN_vkBindImageMemory => gfxBindImageMemory,
|
||||||
|
vkCreateImageView, PFN_vkCreateImageView => gfxCreateImageView,
|
||||||
|
vkDestroyImageView, PFN_vkDestroyImageView => gfxDestroyImageView,
|
||||||
|
|
||||||
|
vkCreateRenderPass, PFN_vkCreateRenderPass => gfxCreateRenderPass,
|
||||||
|
vkDestroyRenderPass, PFN_vkDestroyRenderPass => gfxDestroyRenderPass,
|
||||||
|
vkCreateFramebuffer, PFN_vkCreateFramebuffer => gfxCreateFramebuffer,
|
||||||
|
vkDestroyFramebuffer, PFN_vkDestroyFramebuffer => gfxDestroyFramebuffer,
|
||||||
|
|
||||||
|
vkCreatePipelineLayout, PFN_vkCreatePipelineLayout => gfxCreatePipelineLayout,
|
||||||
|
vkDestroyPipelineLayout, PFN_vkDestroyPipelineLayout => gfxDestroyPipelineLayout,
|
||||||
|
vkCreateGraphicsPipelines, PFN_vkCreateGraphicsPipelines => gfxCreateGraphicsPipelines,
|
||||||
|
vkDestroyPipeline, PFN_vkDestroyPipeline => gfxDestroyPipeline,
|
||||||
|
|
||||||
|
vkCreateCommandPool, PFN_vkCreateCommandPool => gfxCreateCommandPool,
|
||||||
|
vkDestroyCommandPool, PFN_vkDestroyCommandPool => gfxDestroyCommandPool,
|
||||||
|
vkAllocateCommandBuffers, PFN_vkAllocateCommandBuffers => gfxAllocateCommandBuffers,
|
||||||
|
vkFreeCommandBuffers, PFN_vkFreeCommandBuffers => gfxFreeCommandBuffers,
|
||||||
|
vkBeginCommandBuffer, PFN_vkBeginCommandBuffer => gfxBeginCommandBuffer,
|
||||||
|
vkEndCommandBuffer, PFN_vkEndCommandBuffer => gfxEndCommandBuffer,
|
||||||
|
|
||||||
|
vkCreateFence, PFN_vkCreateFence => gfxCreateFence,
|
||||||
|
vkDestroyFence, PFN_vkDestroyFence => gfxDestroyFence,
|
||||||
|
vkWaitForFences, PFN_vkWaitForFences => gfxWaitForFences,
|
||||||
|
vkResetFences, PFN_vkResetFences => gfxResetFences,
|
||||||
|
|
||||||
|
vkQueueSubmit, PFN_vkQueueSubmit => gfxQueueSubmit,
|
||||||
|
|
||||||
|
vkCmdPipelineBarrier, PFN_vkCmdPipelineBarrier => gfxCmdPipelineBarrier,
|
||||||
|
vkCmdBeginRenderPass, PFN_vkCmdBeginRenderPass => gfxCmdBeginRenderPass,
|
||||||
|
vkCmdEndRenderPass, PFN_vkCmdEndRenderPass => gfxCmdEndRenderPass,
|
||||||
|
vkCmdBindPipeline, PFN_vkCmdBindPipeline => gfxCmdBindPipeline,
|
||||||
|
vkCmdBindVertexBuffers, PFN_vkCmdBindVertexBuffers => gfxCmdBindVertexBuffers,
|
||||||
|
vkCmdDraw, PFN_vkCmdDraw => gfxCmdDraw,
|
||||||
|
vkCmdCopyImageToBuffer, PFN_vkCmdCopyImageToBuffer => gfxCmdCopyImageToBuffer,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -530,25 +585,39 @@ pub extern "C" fn gfxUnmapMemory(gpu: VkDevice, memory: VkDeviceMemory) {
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxFlushMappedMemoryRanges(
|
pub extern "C" fn gfxFlushMappedMemoryRanges(
|
||||||
device: VkDevice,
|
gpu: VkDevice,
|
||||||
memoryRangeCount: u32,
|
memoryRangeCount: u32,
|
||||||
pMemoryRanges: *const VkMappedMemoryRange,
|
pMemoryRanges: *const VkMappedMemoryRange,
|
||||||
) -> VkResult {
|
) -> VkResult {
|
||||||
unimplemented!()
|
let ranges = unsafe {
|
||||||
|
slice::from_raw_parts(pMemoryRanges, memoryRangeCount as _)
|
||||||
|
}
|
||||||
|
.iter()
|
||||||
|
.map(|r| (&*r.memory, r.offset .. r.offset + r.size));
|
||||||
|
|
||||||
|
gpu.device.flush_mapped_memory_ranges(ranges);
|
||||||
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxInvalidateMappedMemoryRanges(
|
pub extern "C" fn gfxInvalidateMappedMemoryRanges(
|
||||||
device: VkDevice,
|
gpu: VkDevice,
|
||||||
memoryRangeCount: u32,
|
memoryRangeCount: u32,
|
||||||
pMemoryRanges: *const VkMappedMemoryRange,
|
pMemoryRanges: *const VkMappedMemoryRange,
|
||||||
) -> VkResult {
|
) -> VkResult {
|
||||||
unimplemented!()
|
let ranges = unsafe {
|
||||||
|
slice::from_raw_parts(pMemoryRanges, memoryRangeCount as _)
|
||||||
|
}
|
||||||
|
.iter()
|
||||||
|
.map(|r| (&*r.memory, r.offset .. r.offset + r.size));
|
||||||
|
|
||||||
|
gpu.device.invalidate_mapped_memory_ranges(ranges);
|
||||||
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxGetDeviceMemoryCommitment(
|
pub extern "C" fn gfxGetDeviceMemoryCommitment(
|
||||||
device: VkDevice,
|
_device: VkDevice,
|
||||||
memory: VkDeviceMemory,
|
_memory: VkDeviceMemory,
|
||||||
pCommittedMemoryInBytes: *mut VkDeviceSize,
|
_pCommittedMemoryInBytes: *mut VkDeviceSize,
|
||||||
) {
|
) {
|
||||||
unimplemented!()
|
unimplemented!()
|
||||||
}
|
}
|
||||||
|
@ -1246,11 +1315,13 @@ pub extern "C" fn gfxCreateGraphicsPipelines(
|
||||||
.collect();
|
.collect();
|
||||||
}
|
}
|
||||||
|
|
||||||
assert!(info.pMultisampleState.is_null());
|
|
||||||
|
|
||||||
blend_desc
|
blend_desc
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if !info.pMultisampleState.is_null() {
|
||||||
|
warn!("Multisampling is not supported yet");
|
||||||
|
}
|
||||||
|
|
||||||
// TODO: `pDepthStencilState` could contain garbage, but implementations
|
// TODO: `pDepthStencilState` could contain garbage, but implementations
|
||||||
// can ignore it in some circumstances. How to handle it?
|
// can ignore it in some circumstances. How to handle it?
|
||||||
let depth_stencil = unsafe { info
|
let depth_stencil = unsafe { info
|
||||||
|
@ -1808,7 +1879,8 @@ pub extern "C" fn gfxCreateRenderPass(
|
||||||
let resolve = if subpass.pResolveAttachments.is_null() {
|
let resolve = if subpass.pResolveAttachments.is_null() {
|
||||||
Vec::new()
|
Vec::new()
|
||||||
} else {
|
} else {
|
||||||
unimplemented!()
|
warn!("TODO: implement resolve attachments");
|
||||||
|
Vec::new()
|
||||||
/*
|
/*
|
||||||
unsafe {
|
unsafe {
|
||||||
slice::from_raw_parts(subpass.pResolveAttachments, subpass.colorAttachmentCount as _)
|
slice::from_raw_parts(subpass.pResolveAttachments, subpass.colorAttachmentCount as _)
|
||||||
|
@ -1879,8 +1951,8 @@ pub extern "C" fn gfxCreateRenderPass(
|
||||||
|
|
||||||
// Our portability implementation only supports image access flags atm.
|
// Our portability implementation only supports image access flags atm.
|
||||||
// Global buffer barriers can't be handled currently.
|
// Global buffer barriers can't be handled currently.
|
||||||
let src_access = conv::map_image_acces(dependency.srcAccessMask);
|
let src_access = conv::map_image_access(dependency.srcAccessMask);
|
||||||
let dst_access = conv::map_image_acces(dependency.dstAccessMask);
|
let dst_access = conv::map_image_access(dependency.dstAccessMask);
|
||||||
|
|
||||||
pass::SubpassDependency {
|
pass::SubpassDependency {
|
||||||
passes: src_pass .. dst_pass,
|
passes: src_pass .. dst_pass,
|
||||||
|
@ -1972,8 +2044,8 @@ pub extern "C" fn gfxAllocateCommandBuffers(
|
||||||
) -> VkResult {
|
) -> VkResult {
|
||||||
let info = unsafe { &mut *(pAllocateInfo as *mut VkCommandBufferAllocateInfo) };
|
let info = unsafe { &mut *(pAllocateInfo as *mut VkCommandBufferAllocateInfo) };
|
||||||
let level = match info.level {
|
let level = match info.level {
|
||||||
VkCommandBufferLevel::VK_COMMAND_BUFFER_LEVEL_PRIMARY => RawLevel::Primary,
|
VkCommandBufferLevel::VK_COMMAND_BUFFER_LEVEL_PRIMARY => com::RawLevel::Primary,
|
||||||
VkCommandBufferLevel::VK_COMMAND_BUFFER_LEVEL_SECONDARY => RawLevel::Secondary,
|
VkCommandBufferLevel::VK_COMMAND_BUFFER_LEVEL_SECONDARY => com::RawLevel::Secondary,
|
||||||
level => panic!("Unexpected command buffer lvel: {:?}", level),
|
level => panic!("Unexpected command buffer lvel: {:?}", level),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -2048,8 +2120,8 @@ pub extern "C" fn gfxCmdSetViewport(
|
||||||
slice::from_raw_parts(pViewports, viewportCount as _)
|
slice::from_raw_parts(pViewports, viewportCount as _)
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|viewport| {
|
.map(|viewport| {
|
||||||
Viewport {
|
com::Viewport {
|
||||||
rect: Rect {
|
rect: com::Rect {
|
||||||
x: viewport.x as _,
|
x: viewport.x as _,
|
||||||
y: viewport.y as _,
|
y: viewport.y as _,
|
||||||
w: viewport.width as _,
|
w: viewport.width as _,
|
||||||
|
@ -2075,7 +2147,7 @@ pub extern "C" fn gfxCmdSetScissor(
|
||||||
slice::from_raw_parts(pScissors, scissorCount as _)
|
slice::from_raw_parts(pScissors, scissorCount as _)
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|scissor| {
|
.map(|scissor| {
|
||||||
Rect {
|
com::Rect {
|
||||||
x: scissor.offset.x as _,
|
x: scissor.offset.x as _,
|
||||||
y: scissor.offset.y as _,
|
y: scissor.offset.y as _,
|
||||||
w: scissor.extent.width as _,
|
w: scissor.extent.width as _,
|
||||||
|
@ -2314,25 +2386,73 @@ pub extern "C" fn gfxCmdBlitImage(
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxCmdCopyBufferToImage(
|
pub extern "C" fn gfxCmdCopyBufferToImage(
|
||||||
commandBuffer: VkCommandBuffer,
|
mut commandBuffer: VkCommandBuffer,
|
||||||
srcBuffer: VkBuffer,
|
srcBuffer: VkBuffer,
|
||||||
dstImage: VkImage,
|
dstImage: VkImage,
|
||||||
dstImageLayout: VkImageLayout,
|
dstImageLayout: VkImageLayout,
|
||||||
regionCount: u32,
|
regionCount: u32,
|
||||||
pRegions: *const VkBufferImageCopy,
|
pRegions: *const VkBufferImageCopy,
|
||||||
) {
|
) {
|
||||||
unimplemented!()
|
let regions = unsafe {
|
||||||
|
slice::from_raw_parts(pRegions, regionCount as _)
|
||||||
|
}
|
||||||
|
.iter()
|
||||||
|
.map(|r| com::BufferImageCopy {
|
||||||
|
buffer_offset: r.bufferOffset,
|
||||||
|
buffer_width: r.bufferRowLength,
|
||||||
|
buffer_height: r.bufferImageHeight,
|
||||||
|
image_layers: conv::map_subresource_layers(r.imageSubresource),
|
||||||
|
image_offset: conv::map_offset(r.imageOffset),
|
||||||
|
image_extent: conv::map_extent(r.imageExtent),
|
||||||
|
});
|
||||||
|
|
||||||
|
commandBuffer.copy_buffer_to_image(
|
||||||
|
match *srcBuffer {
|
||||||
|
Buffer::Buffer(ref b) => b,
|
||||||
|
Buffer::Unbound(_) => panic!("Bound buffer expected!"),
|
||||||
|
},
|
||||||
|
match *dstImage {
|
||||||
|
Image::Image(ref i) => i,
|
||||||
|
Image::Unbound(_) => panic!("Bound image expected!"),
|
||||||
|
},
|
||||||
|
conv::map_image_layout(dstImageLayout),
|
||||||
|
regions,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxCmdCopyImageToBuffer(
|
pub extern "C" fn gfxCmdCopyImageToBuffer(
|
||||||
commandBuffer: VkCommandBuffer,
|
mut commandBuffer: VkCommandBuffer,
|
||||||
srcImage: VkImage,
|
srcImage: VkImage,
|
||||||
srcImageLayout: VkImageLayout,
|
srcImageLayout: VkImageLayout,
|
||||||
dstBuffer: VkBuffer,
|
dstBuffer: VkBuffer,
|
||||||
regionCount: u32,
|
regionCount: u32,
|
||||||
pRegions: *const VkBufferImageCopy,
|
pRegions: *const VkBufferImageCopy,
|
||||||
) {
|
) {
|
||||||
unimplemented!()
|
let regions = unsafe {
|
||||||
|
slice::from_raw_parts(pRegions, regionCount as _)
|
||||||
|
}
|
||||||
|
.iter()
|
||||||
|
.map(|r| com::BufferImageCopy {
|
||||||
|
buffer_offset: r.bufferOffset,
|
||||||
|
buffer_width: r.bufferRowLength,
|
||||||
|
buffer_height: r.bufferImageHeight,
|
||||||
|
image_layers: conv::map_subresource_layers(r.imageSubresource),
|
||||||
|
image_offset: conv::map_offset(r.imageOffset),
|
||||||
|
image_extent: conv::map_extent(r.imageExtent),
|
||||||
|
});
|
||||||
|
|
||||||
|
commandBuffer.copy_image_to_buffer(
|
||||||
|
match *srcImage {
|
||||||
|
Image::Image(ref i) => i,
|
||||||
|
Image::Unbound(_) => panic!("Bound image expected!"),
|
||||||
|
},
|
||||||
|
conv::map_image_layout(srcImageLayout),
|
||||||
|
match *dstBuffer {
|
||||||
|
Buffer::Buffer(ref b) => b,
|
||||||
|
Buffer::Unbound(_) => panic!("Bound buffer expected!"),
|
||||||
|
},
|
||||||
|
regions,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxCmdUpdateBuffer(
|
pub extern "C" fn gfxCmdUpdateBuffer(
|
||||||
|
@ -2432,18 +2552,47 @@ pub extern "C" fn gfxCmdWaitEvents(
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxCmdPipelineBarrier(
|
pub extern "C" fn gfxCmdPipelineBarrier(
|
||||||
commandBuffer: VkCommandBuffer,
|
mut commandBuffer: VkCommandBuffer,
|
||||||
srcStageMask: VkPipelineStageFlags,
|
srcStageMask: VkPipelineStageFlags,
|
||||||
dstStageMask: VkPipelineStageFlags,
|
dstStageMask: VkPipelineStageFlags,
|
||||||
dependencyFlags: VkDependencyFlags,
|
_dependencyFlags: VkDependencyFlags,
|
||||||
memoryBarrierCount: u32,
|
_memoryBarrierCount: u32,
|
||||||
pMemoryBarriers: *const VkMemoryBarrier,
|
_pMemoryBarriers: *const VkMemoryBarrier,
|
||||||
bufferMemoryBarrierCount: u32,
|
bufferMemoryBarrierCount: u32,
|
||||||
pBufferMemoryBarriers: *const VkBufferMemoryBarrier,
|
pBufferMemoryBarriers: *const VkBufferMemoryBarrier,
|
||||||
imageMemoryBarrierCount: u32,
|
imageMemoryBarrierCount: u32,
|
||||||
pImageMemoryBarriers: *const VkImageMemoryBarrier,
|
pImageMemoryBarriers: *const VkImageMemoryBarrier,
|
||||||
) {
|
) {
|
||||||
unimplemented!()
|
let buffer_barriers = unsafe {
|
||||||
|
slice::from_raw_parts(pBufferMemoryBarriers, bufferMemoryBarrierCount as _)
|
||||||
|
}
|
||||||
|
.iter()
|
||||||
|
.map(|b| memory::Barrier::Buffer {
|
||||||
|
states: conv::map_buffer_access(b.srcAccessMask) .. conv::map_buffer_access(b.dstAccessMask),
|
||||||
|
target: match *b.buffer {
|
||||||
|
Buffer::Buffer(ref b) => b,
|
||||||
|
Buffer::Unbound(_) => panic!("Bound buffer is needed here!"),
|
||||||
|
},
|
||||||
|
});
|
||||||
|
let image_barriers = unsafe {
|
||||||
|
slice::from_raw_parts(pImageMemoryBarriers, imageMemoryBarrierCount as _)
|
||||||
|
}
|
||||||
|
.iter()
|
||||||
|
.map(|b| memory::Barrier::Image {
|
||||||
|
states:
|
||||||
|
(conv::map_image_access(b.srcAccessMask), conv::map_image_layout(b.oldLayout)) ..
|
||||||
|
(conv::map_image_access(b.dstAccessMask), conv::map_image_layout(b.newLayout)),
|
||||||
|
target: match *b.image {
|
||||||
|
Image::Image(ref i) => i,
|
||||||
|
Image::Unbound(_) => panic!("Bound image is needed here!"),
|
||||||
|
},
|
||||||
|
range: conv::map_subresource_range(b.subresourceRange),
|
||||||
|
});
|
||||||
|
|
||||||
|
commandBuffer.pipeline_barrier(
|
||||||
|
conv::map_pipeline_stage_flags(srcStageMask) .. conv::map_pipeline_stage_flags(dstStageMask),
|
||||||
|
buffer_barriers.chain(image_barriers),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxCmdBeginQuery(
|
pub extern "C" fn gfxCmdBeginQuery(
|
||||||
|
@ -2512,7 +2661,7 @@ pub extern "C" fn gfxCmdBeginRenderPass(
|
||||||
) {
|
) {
|
||||||
let info = unsafe { &*pRenderPassBegin };
|
let info = unsafe { &*pRenderPassBegin };
|
||||||
|
|
||||||
let render_area = Rect {
|
let render_area = com::Rect {
|
||||||
x: info.renderArea.offset.x as _,
|
x: info.renderArea.offset.x as _,
|
||||||
y: info.renderArea.offset.y as _,
|
y: info.renderArea.offset.y as _,
|
||||||
w: info.renderArea.extent.width as _,
|
w: info.renderArea.extent.width as _,
|
||||||
|
@ -2523,7 +2672,7 @@ pub extern "C" fn gfxCmdBeginRenderPass(
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|cv| {
|
.map(|cv| {
|
||||||
// HAL and Vulkan clear value union sharing same memory representation
|
// HAL and Vulkan clear value union sharing same memory representation
|
||||||
mem::transmute::<_, ClearValueRaw>(*cv)
|
mem::transmute::<_, com::ClearValueRaw>(*cv)
|
||||||
})
|
})
|
||||||
};
|
};
|
||||||
let contents = conv::map_subpass_contents(contents);
|
let contents = conv::map_subpass_contents(contents);
|
||||||
|
|
|
@ -11,6 +11,8 @@ extern crate gfx_backend_vulkan as back;
|
||||||
|
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
extern crate lazy_static;
|
extern crate lazy_static;
|
||||||
|
#[macro_use]
|
||||||
|
extern crate log;
|
||||||
|
|
||||||
mod conv;
|
mod conv;
|
||||||
mod handle;
|
mod handle;
|
||||||
|
|
Loading…
Reference in a new issue