mirror of
https://github.com/italicsjenga/portability.git
synced 2024-11-26 08:51:31 +11:00
ICD implementation groundwork
This commit is contained in:
parent
428899f237
commit
b919665a9b
|
@ -6,6 +6,9 @@ authors = ["Dzmitry Malyshau <kvark@mozilla.com>"]
|
||||||
[lib]
|
[lib]
|
||||||
name = "portability_gfx"
|
name = "portability_gfx"
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
lazy_static = "1.0"
|
||||||
|
|
||||||
[dependencies.gfx-hal]
|
[dependencies.gfx-hal]
|
||||||
#path = "../gfx/src/hal"
|
#path = "../gfx/src/hal"
|
||||||
git = "https://github.com/kvark/gfx-rs"
|
git = "https://github.com/kvark/gfx-rs"
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
use std::mem;
|
||||||
|
|
||||||
pub fn gfxCreateInstance(
|
pub extern fn gfxCreateInstance(
|
||||||
_pCreateInfo: *const VkInstanceCreateInfo,
|
_pCreateInfo: *const VkInstanceCreateInfo,
|
||||||
_pAllocator: *const VkAllocationCallbacks,
|
_pAllocator: *const VkAllocationCallbacks,
|
||||||
pInstance: *mut VkInstance,
|
pInstance: *mut VkInstance,
|
||||||
|
@ -11,7 +12,7 @@ pub fn gfxCreateInstance(
|
||||||
VkResult::VK_SUCCESS
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxDestroyInstance(
|
pub extern fn gfxDestroyInstance(
|
||||||
instance: VkInstance,
|
instance: VkInstance,
|
||||||
_pAllocator: *const VkAllocationCallbacks,
|
_pAllocator: *const VkAllocationCallbacks,
|
||||||
) {
|
) {
|
||||||
|
@ -19,7 +20,7 @@ pub fn gfxDestroyInstance(
|
||||||
//let it drop
|
//let it drop
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxEnumeratePhysicalDevices(
|
pub extern fn gfxEnumeratePhysicalDevices(
|
||||||
instance: VkInstance,
|
instance: VkInstance,
|
||||||
pPhysicalDeviceCount: *mut u32,
|
pPhysicalDeviceCount: *mut u32,
|
||||||
pPhysicalDevices: *mut VkPhysicalDevice,
|
pPhysicalDevices: *mut VkPhysicalDevice,
|
||||||
|
@ -36,7 +37,7 @@ pub fn gfxEnumeratePhysicalDevices(
|
||||||
VkResult::VK_SUCCESS
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxGetPhysicalDeviceQueueFamilyProperties(
|
pub extern fn gfxGetPhysicalDeviceQueueFamilyProperties(
|
||||||
adapter: VkPhysicalDevice,
|
adapter: VkPhysicalDevice,
|
||||||
pQueueFamilyPropertyCount: *mut u32,
|
pQueueFamilyPropertyCount: *mut u32,
|
||||||
pQueueFamilyProperties: *mut VkQueueFamilyProperties,
|
pQueueFamilyProperties: *mut VkQueueFamilyProperties,
|
||||||
|
@ -110,7 +111,7 @@ extern "C" {
|
||||||
-> PFN_vkVoidFunction;
|
-> PFN_vkVoidFunction;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxCreateDevice(
|
pub extern fn gfxCreateDevice(
|
||||||
adapter: VkPhysicalDevice,
|
adapter: VkPhysicalDevice,
|
||||||
pCreateInfo: *const VkDeviceCreateInfo,
|
pCreateInfo: *const VkDeviceCreateInfo,
|
||||||
_pAllocator: *const VkAllocationCallbacks,
|
_pAllocator: *const VkAllocationCallbacks,
|
||||||
|
@ -133,21 +134,59 @@ pub fn gfxCreateDevice(
|
||||||
VkResult::VK_SUCCESS
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxDestroyDevice(
|
pub extern fn gfxDestroyDevice(
|
||||||
device: VkDevice,
|
device: VkDevice,
|
||||||
_pAllocator: *const VkAllocationCallbacks,
|
_pAllocator: *const VkAllocationCallbacks,
|
||||||
) {
|
) {
|
||||||
let _ = device.unwrap(); //TODO?
|
let _ = device.unwrap(); //TODO?
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" {
|
lazy_static! {
|
||||||
pub fn vkEnumerateInstanceExtensionProperties(pLayerName:
|
static ref INSTANCE_EXTENSIONS: [VkExtensionProperties; 1] = {
|
||||||
*const ::std::os::raw::c_char,
|
let mut extensions = [
|
||||||
pPropertyCount: *mut u32,
|
VkExtensionProperties {
|
||||||
pProperties:
|
extensionName: [0; 256], // VK_KHR_SURFACE_EXTENSION_NAME
|
||||||
*mut VkExtensionProperties)
|
specVersion: VK_KHR_SURFACE_SPEC_VERSION,
|
||||||
-> VkResult;
|
|
||||||
}
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
extensions[0]
|
||||||
|
.extensionName[..VK_KHR_SURFACE_EXTENSION_NAME.len()]
|
||||||
|
.copy_from_slice(unsafe {
|
||||||
|
mem::transmute(VK_KHR_SURFACE_EXTENSION_NAME as &[u8])
|
||||||
|
});
|
||||||
|
|
||||||
|
extensions
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
pub extern fn gfxEnumerateInstanceExtensionProperties(
|
||||||
|
pLayerName: *const ::std::os::raw::c_char,
|
||||||
|
pPropertyCount: *mut u32,
|
||||||
|
pProperties: *mut VkExtensionProperties,
|
||||||
|
) -> VkResult {
|
||||||
|
let property_count = unsafe { &mut *pPropertyCount };
|
||||||
|
let num_extensions = INSTANCE_EXTENSIONS.len() as u32;
|
||||||
|
|
||||||
|
if pProperties.is_null() {
|
||||||
|
*property_count = num_extensions;
|
||||||
|
} else {
|
||||||
|
if *property_count > num_extensions {
|
||||||
|
*property_count = num_extensions;
|
||||||
|
}
|
||||||
|
let properties = unsafe { slice::from_raw_parts_mut(pProperties, *property_count as usize) };
|
||||||
|
for i in 0..*property_count as usize {
|
||||||
|
properties[i] = INSTANCE_EXTENSIONS[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
if *property_count < num_extensions {
|
||||||
|
return VkResult::VK_INCOMPLETE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
VkResult::VK_SUCCESS
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
pub fn vkEnumerateDeviceExtensionProperties(physicalDevice:
|
pub fn vkEnumerateDeviceExtensionProperties(physicalDevice:
|
||||||
VkPhysicalDevice,
|
VkPhysicalDevice,
|
||||||
|
@ -378,7 +417,7 @@ extern "C" {
|
||||||
*const VkImageSubresource,
|
*const VkImageSubresource,
|
||||||
pLayout: *mut VkSubresourceLayout);
|
pLayout: *mut VkSubresourceLayout);
|
||||||
}
|
}
|
||||||
pub fn gfxCreateImageView(
|
pub extern fn gfxCreateImageView(
|
||||||
gpu: VkDevice,
|
gpu: VkDevice,
|
||||||
pCreateInfo: *const VkImageViewCreateInfo,
|
pCreateInfo: *const VkImageViewCreateInfo,
|
||||||
pAllocator: *const VkAllocationCallbacks,
|
pAllocator: *const VkAllocationCallbacks,
|
||||||
|
@ -407,7 +446,7 @@ pub fn gfxCreateImageView(
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
pub fn gfxDestroyImageView(
|
pub extern fn gfxDestroyImageView(
|
||||||
gpu: VkDevice,
|
gpu: VkDevice,
|
||||||
imageView: VkImageView,
|
imageView: VkImageView,
|
||||||
pAllocator: *const VkAllocationCallbacks,
|
pAllocator: *const VkAllocationCallbacks,
|
||||||
|
@ -580,7 +619,7 @@ extern "C" {
|
||||||
pGranularity: *mut VkExtent2D);
|
pGranularity: *mut VkExtent2D);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxCreateCommandPool(
|
pub extern fn gfxCreateCommandPool(
|
||||||
gpu: VkDevice,
|
gpu: VkDevice,
|
||||||
pCreateInfo: *const VkCommandPoolCreateInfo,
|
pCreateInfo: *const VkCommandPoolCreateInfo,
|
||||||
_pAllocator: *const VkAllocationCallbacks,
|
_pAllocator: *const VkAllocationCallbacks,
|
||||||
|
@ -605,7 +644,7 @@ pub fn gfxCreateCommandPool(
|
||||||
VkResult::VK_SUCCESS
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxDestroyCommandPool(
|
pub extern fn gfxDestroyCommandPool(
|
||||||
gpu: VkDevice,
|
gpu: VkDevice,
|
||||||
commandPool: VkCommandPool,
|
commandPool: VkCommandPool,
|
||||||
_pAllocator: *const VkAllocationCallbacks,
|
_pAllocator: *const VkAllocationCallbacks,
|
||||||
|
@ -613,7 +652,7 @@ pub fn gfxDestroyCommandPool(
|
||||||
gpu.device.destroy_command_pool(*commandPool.unwrap());
|
gpu.device.destroy_command_pool(*commandPool.unwrap());
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxResetCommandPool(
|
pub extern fn gfxResetCommandPool(
|
||||||
_gpu: VkDevice,
|
_gpu: VkDevice,
|
||||||
mut commandPool: VkCommandPool,
|
mut commandPool: VkCommandPool,
|
||||||
_flags: VkCommandPoolResetFlags,
|
_flags: VkCommandPoolResetFlags,
|
||||||
|
@ -622,7 +661,7 @@ pub fn gfxResetCommandPool(
|
||||||
VkResult::VK_SUCCESS
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxAllocateCommandBuffers(
|
pub extern fn gfxAllocateCommandBuffers(
|
||||||
_gpu: VkDevice,
|
_gpu: VkDevice,
|
||||||
pAllocateInfo: *const VkCommandBufferAllocateInfo,
|
pAllocateInfo: *const VkCommandBufferAllocateInfo,
|
||||||
pCommandBuffers: *mut VkCommandBuffer,
|
pCommandBuffers: *mut VkCommandBuffer,
|
||||||
|
@ -643,7 +682,7 @@ pub fn gfxAllocateCommandBuffers(
|
||||||
VkResult::VK_SUCCESS
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxFreeCommandBuffers(
|
pub extern fn gfxFreeCommandBuffers(
|
||||||
_gpu: VkDevice,
|
_gpu: VkDevice,
|
||||||
mut commandPool: VkCommandPool,
|
mut commandPool: VkCommandPool,
|
||||||
commandBufferCount: u32,
|
commandBufferCount: u32,
|
||||||
|
@ -925,7 +964,7 @@ extern "C" {
|
||||||
pCommandBuffers: *const VkCommandBuffer);
|
pCommandBuffers: *const VkCommandBuffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxDestroySurfaceKHR(
|
pub extern fn gfxDestroySurfaceKHR(
|
||||||
_instance: VkInstance,
|
_instance: VkInstance,
|
||||||
surface: VkSurfaceKHR,
|
surface: VkSurfaceKHR,
|
||||||
_: *const VkAllocationCallbacks,
|
_: *const VkAllocationCallbacks,
|
||||||
|
@ -933,7 +972,7 @@ pub fn gfxDestroySurfaceKHR(
|
||||||
let _ = surface.unwrap(); //TODO
|
let _ = surface.unwrap(); //TODO
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxGetPhysicalDeviceSurfaceSupportKHR(
|
pub extern fn gfxGetPhysicalDeviceSurfaceSupportKHR(
|
||||||
adapter: VkPhysicalDevice,
|
adapter: VkPhysicalDevice,
|
||||||
queueFamilyIndex: u32,
|
queueFamilyIndex: u32,
|
||||||
surface: VkSurfaceKHR,
|
surface: VkSurfaceKHR,
|
||||||
|
@ -945,7 +984,7 @@ pub fn gfxGetPhysicalDeviceSurfaceSupportKHR(
|
||||||
VkResult::VK_SUCCESS
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxGetPhysicalDeviceSurfaceCapabilitiesKHR(
|
pub extern fn gfxGetPhysicalDeviceSurfaceCapabilitiesKHR(
|
||||||
adapter: VkPhysicalDevice,
|
adapter: VkPhysicalDevice,
|
||||||
surface: VkSurfaceKHR,
|
surface: VkSurfaceKHR,
|
||||||
pSurfaceCapabilities: *mut VkSurfaceCapabilitiesKHR,
|
pSurfaceCapabilities: *mut VkSurfaceCapabilitiesKHR,
|
||||||
|
@ -975,7 +1014,7 @@ pub fn gfxGetPhysicalDeviceSurfaceCapabilitiesKHR(
|
||||||
VkResult::VK_SUCCESS
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxGetPhysicalDeviceSurfaceFormatsKHR(
|
pub extern fn gfxGetPhysicalDeviceSurfaceFormatsKHR(
|
||||||
adapter: VkPhysicalDevice,
|
adapter: VkPhysicalDevice,
|
||||||
surface: VkSurfaceKHR,
|
surface: VkSurfaceKHR,
|
||||||
pSurfaceFormatCount: *mut u32,
|
pSurfaceFormatCount: *mut u32,
|
||||||
|
@ -997,7 +1036,7 @@ pub fn gfxGetPhysicalDeviceSurfaceFormatsKHR(
|
||||||
VkResult::VK_SUCCESS
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn gfxGetPhysicalDeviceSurfacePresentModesKHR(
|
pub extern fn gfxGetPhysicalDeviceSurfacePresentModesKHR(
|
||||||
_adapter: VkPhysicalDevice,
|
_adapter: VkPhysicalDevice,
|
||||||
_surface: VkSurfaceKHR,
|
_surface: VkSurfaceKHR,
|
||||||
pPresentModeCount: *mut u32,
|
pPresentModeCount: *mut u32,
|
||||||
|
@ -1016,6 +1055,83 @@ pub fn gfxGetPhysicalDeviceSurfacePresentModesKHR(
|
||||||
VkResult::VK_SUCCESS
|
VkResult::VK_SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub extern fn gfxCreateSwapchainKHR(
|
||||||
|
gpu: VkDevice,
|
||||||
|
pCreateInfo: *const VkSwapchainCreateInfoKHR,
|
||||||
|
_pAllocator: *const VkAllocationCallbacks,
|
||||||
|
pSwapchain: *mut VkSwapchainKHR,
|
||||||
|
) -> VkResult {
|
||||||
|
let info = unsafe { &*pCreateInfo };
|
||||||
|
// TODO: more checks
|
||||||
|
assert_eq!(info.clipped, VK_TRUE); // TODO
|
||||||
|
assert_eq!(info.imageSharingMode, VkSharingMode::VK_SHARING_MODE_EXCLUSIVE); // TODO
|
||||||
|
|
||||||
|
let config = hal::SwapchainConfig {
|
||||||
|
color_format: conv::hal_from_format(info.imageFormat),
|
||||||
|
depth_stencil_format: None,
|
||||||
|
image_count: info.minImageCount,
|
||||||
|
};
|
||||||
|
let (swapchain, backbuffers) = gpu.device.create_swapchain(&mut info.surface.clone(), config);
|
||||||
|
|
||||||
|
let images = match backbuffers {
|
||||||
|
hal::Backbuffer::Images(images) => {
|
||||||
|
images.into_iter().map(|image| Handle::new(image)).collect()
|
||||||
|
},
|
||||||
|
hal::Backbuffer::Framebuffer(_) => {
|
||||||
|
panic!("Expected backbuffer images. Backends returning only framebuffers are not supported!")
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
let swapchain = Swapchain {
|
||||||
|
raw: swapchain,
|
||||||
|
images,
|
||||||
|
};
|
||||||
|
|
||||||
|
unsafe { *pSwapchain = Handle::new(swapchain) };
|
||||||
|
VkResult::VK_SUCCESS
|
||||||
|
}
|
||||||
|
pub extern fn gfxDestroySwapchainKHR(
|
||||||
|
device: VkDevice,
|
||||||
|
mut swapchain: VkSwapchainKHR,
|
||||||
|
pAllocator: *const VkAllocationCallbacks,
|
||||||
|
) {
|
||||||
|
for image in &mut swapchain.images {
|
||||||
|
let _ = image.unwrap();
|
||||||
|
}
|
||||||
|
let _ = swapchain.unwrap();
|
||||||
|
}
|
||||||
|
pub extern fn gfxGetSwapchainImagesKHR(
|
||||||
|
device: VkDevice,
|
||||||
|
swapchain: VkSwapchainKHR,
|
||||||
|
pSwapchainImageCount: *mut u32,
|
||||||
|
pSwapchainImages: *mut VkImage,
|
||||||
|
) -> VkResult {
|
||||||
|
debug_assert!(!pSwapchainImageCount.is_null());
|
||||||
|
|
||||||
|
let swapchain_image_count = unsafe { &mut*pSwapchainImageCount };
|
||||||
|
let available_images = swapchain.images.len() as u32;
|
||||||
|
|
||||||
|
if pSwapchainImages.is_null() {
|
||||||
|
// If NULL the number of presentable images is returned.
|
||||||
|
*swapchain_image_count = available_images;
|
||||||
|
} else {
|
||||||
|
*swapchain_image_count = available_images.min(*swapchain_image_count);
|
||||||
|
let swapchain_images = unsafe {
|
||||||
|
slice::from_raw_parts_mut(pSwapchainImages, *swapchain_image_count as _)
|
||||||
|
};
|
||||||
|
|
||||||
|
for i in 0..*swapchain_image_count as _ {
|
||||||
|
swapchain_images[i] = swapchain.images[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
if *swapchain_image_count < available_images {
|
||||||
|
return VkResult::VK_INCOMPLETE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
VkResult::VK_SUCCESS
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
pub fn vkCmdProcessCommandsNVX(commandBuffer: VkCommandBuffer,
|
pub fn vkCmdProcessCommandsNVX(commandBuffer: VkCommandBuffer,
|
||||||
pProcessCommandsInfo:
|
pProcessCommandsInfo:
|
||||||
|
|
|
@ -5,6 +5,8 @@
|
||||||
|
|
||||||
extern crate gfx_hal as hal;
|
extern crate gfx_hal as hal;
|
||||||
extern crate gfx_backend_vulkan as back;
|
extern crate gfx_backend_vulkan as back;
|
||||||
|
#[macro_use]
|
||||||
|
extern crate lazy_static;
|
||||||
|
|
||||||
mod conv;
|
mod conv;
|
||||||
mod handle;
|
mod handle;
|
||||||
|
@ -4527,85 +4529,6 @@ pub type PFN_vkQueuePresentKHR =
|
||||||
pPresentInfo:
|
pPresentInfo:
|
||||||
*const VkPresentInfoKHR)
|
*const VkPresentInfoKHR)
|
||||||
-> VkResult>;
|
-> VkResult>;
|
||||||
pub fn gfxCreateSwapchainKHR(
|
|
||||||
gpu: VkDevice,
|
|
||||||
pCreateInfo: *const VkSwapchainCreateInfoKHR,
|
|
||||||
_pAllocator: *const VkAllocationCallbacks,
|
|
||||||
pSwapchain: *mut VkSwapchainKHR,
|
|
||||||
) -> VkResult {
|
|
||||||
let info = unsafe { &*pCreateInfo };
|
|
||||||
// TODO: more checks
|
|
||||||
assert_eq!(info.clipped, VK_TRUE); // TODO
|
|
||||||
assert_eq!(info.imageSharingMode, VkSharingMode::VK_SHARING_MODE_EXCLUSIVE); // TODO
|
|
||||||
|
|
||||||
let config = hal::SwapchainConfig {
|
|
||||||
color_format: conv::hal_from_format(info.imageFormat),
|
|
||||||
depth_stencil_format: None,
|
|
||||||
image_count: info.minImageCount,
|
|
||||||
};
|
|
||||||
let (swapchain, backbuffers) = gpu.device.create_swapchain(&mut info.surface.clone(), config);
|
|
||||||
|
|
||||||
let images = match backbuffers {
|
|
||||||
hal::Backbuffer::Images(images) => {
|
|
||||||
images.into_iter().map(|image| Handle::new(image)).collect()
|
|
||||||
},
|
|
||||||
hal::Backbuffer::Framebuffer(_) => {
|
|
||||||
panic!("Expected backbuffer images. Backends returning only framebuffers are not supported!")
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
let swapchain = Swapchain {
|
|
||||||
raw: swapchain,
|
|
||||||
images,
|
|
||||||
};
|
|
||||||
|
|
||||||
unsafe { *pSwapchain = Handle::new(swapchain) };
|
|
||||||
VkResult::VK_SUCCESS
|
|
||||||
}
|
|
||||||
pub fn gfxDestroySwapchainKHR(
|
|
||||||
device: VkDevice,
|
|
||||||
mut swapchain: VkSwapchainKHR,
|
|
||||||
pAllocator: *const VkAllocationCallbacks,
|
|
||||||
) {
|
|
||||||
for image in &mut swapchain.images {
|
|
||||||
let _ = image.unwrap();
|
|
||||||
}
|
|
||||||
let _ = swapchain.unwrap();
|
|
||||||
}
|
|
||||||
pub fn gfxGetSwapchainImagesKHR(
|
|
||||||
device: VkDevice,
|
|
||||||
swapchain: VkSwapchainKHR,
|
|
||||||
pSwapchainImageCount: *mut u32,
|
|
||||||
pSwapchainImages: *mut VkImage,
|
|
||||||
) -> VkResult {
|
|
||||||
debug_assert!(!pSwapchainImageCount.is_null());
|
|
||||||
|
|
||||||
let swapchain_image_count = unsafe { *pSwapchainImageCount };
|
|
||||||
let available_images = swapchain.images.len();
|
|
||||||
|
|
||||||
if pSwapchainImages.is_null() {
|
|
||||||
// If NULL the number of presentable images is returned.
|
|
||||||
unsafe { *pSwapchainImageCount = swapchain.images.len() as _; }
|
|
||||||
} else {
|
|
||||||
let num_images = available_images.min(swapchain_image_count as _);
|
|
||||||
let swapchain_images = unsafe {
|
|
||||||
slice::from_raw_parts_mut(pSwapchainImages, num_images)
|
|
||||||
};
|
|
||||||
|
|
||||||
for i in 0..num_images as _ {
|
|
||||||
swapchain_images[i] = swapchain.images[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Overwrite pSwapchainImageCount with actual image count
|
|
||||||
unsafe { *pSwapchainImageCount = num_images as _; }
|
|
||||||
|
|
||||||
if num_images < available_images {
|
|
||||||
return VkResult::VK_INCOMPLETE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
VkResult::VK_SUCCESS
|
|
||||||
}
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
pub fn vkAcquireNextImageKHR(device: VkDevice, swapchain: VkSwapchainKHR,
|
pub fn vkAcquireNextImageKHR(device: VkDevice, swapchain: VkSwapchainKHR,
|
||||||
timeout: u64, semaphore: VkSemaphore,
|
timeout: u64, semaphore: VkSemaphore,
|
||||||
|
|
7
libportability-icd/portability_debug.json
Normal file
7
libportability-icd/portability_debug.json
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
{
|
||||||
|
"file_format_version": "1.0.0",
|
||||||
|
"ICD": {
|
||||||
|
"library_path": "..\\target\\debug\\portability_icd.dll",
|
||||||
|
"api_version": "1.0.0"
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,3 +1,58 @@
|
||||||
|
#![allow(non_snake_case)]
|
||||||
|
|
||||||
extern crate portability_gfx;
|
extern crate portability_gfx;
|
||||||
|
|
||||||
use portability_gfx::*;
|
use portability_gfx::*;
|
||||||
|
|
||||||
|
use std::ffi::CStr;
|
||||||
|
use std::mem;
|
||||||
|
use std::ptr;
|
||||||
|
|
||||||
|
const ICD_VERSION: u32 = 5;
|
||||||
|
|
||||||
|
macro_rules! proc_addr {
|
||||||
|
($name:expr, $($vk:pat => $gfx:expr),*) => (
|
||||||
|
match $name {
|
||||||
|
$(
|
||||||
|
stringify!($vk) => unsafe { mem::transmute::<_, PFN_vkVoidFunction>($gfx as *const ()) }
|
||||||
|
),*
|
||||||
|
_ => None
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[no_mangle]
|
||||||
|
pub extern fn vk_icdGetInstanceProcAddr(
|
||||||
|
instance: VkInstance, pName: *const ::std::os::raw::c_char,
|
||||||
|
) -> PFN_vkVoidFunction {
|
||||||
|
let name = unsafe { CStr::from_ptr(pName) };
|
||||||
|
let name = match name.to_str() {
|
||||||
|
Ok(name) => name,
|
||||||
|
Err(_) => return None,
|
||||||
|
};
|
||||||
|
|
||||||
|
proc_addr!{ name,
|
||||||
|
vkCreateInstance => gfxCreateInstance,
|
||||||
|
vkEnumerateInstanceExtensionProperties => gfxEnumerateInstanceExtensionProperties
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[no_mangle]
|
||||||
|
pub extern fn vk_icdNegotiateLoaderICDInterfaceVersion(
|
||||||
|
pSupportedVersion: *mut ::std::os::raw::c_uint,
|
||||||
|
) -> VkResult {
|
||||||
|
let supported_version = unsafe { &mut *pSupportedVersion };
|
||||||
|
if *supported_version > ICD_VERSION {
|
||||||
|
*supported_version = ICD_VERSION;
|
||||||
|
}
|
||||||
|
|
||||||
|
VkResult::VK_SUCCESS
|
||||||
|
}
|
||||||
|
|
||||||
|
#[no_mangle]
|
||||||
|
pub extern fn vk_icdGetPhysicalDeviceProcAddr(
|
||||||
|
instance: VkInstance, pName: *const ::std::os::raw::c_char,
|
||||||
|
) -> PFN_vkVoidFunction {
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue