mirror of
https://github.com/italicsjenga/portability.git
synced 2024-11-26 08:51:31 +11:00
Cull flags, dynamic states, and dynamic buffers
This commit is contained in:
parent
0012de8dfe
commit
149e91a827
14
Cargo.lock
generated
14
Cargo.lock
generated
|
@ -252,7 +252,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "gfx-backend-dx12"
|
name = "gfx-backend-dx12"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/gfx-rs/gfx#505e8057803d8cc0302b5fdcfe7ae807b8f3b8cf"
|
source = "git+https://github.com/gfx-rs/gfx#f3d012dcfb75cfa363c4858d110a8469f002313d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"bitflags 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"derivative 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"derivative 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
@ -268,7 +268,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "gfx-backend-metal"
|
name = "gfx-backend-metal"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/gfx-rs/gfx#505e8057803d8cc0302b5fdcfe7ae807b8f3b8cf"
|
source = "git+https://github.com/gfx-rs/gfx#f3d012dcfb75cfa363c4858d110a8469f002313d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"bitflags 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"block 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
"block 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
@ -283,14 +283,14 @@ dependencies = [
|
||||||
"metal-rs 0.10.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"metal-rs 0.10.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"objc 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"objc 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"smallvec 0.6.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"smallvec 0.6.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"spirv_cross 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"spirv_cross 0.9.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"winit 0.13.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"winit 0.13.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "gfx-backend-vulkan"
|
name = "gfx-backend-vulkan"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/gfx-rs/gfx#505e8057803d8cc0302b5fdcfe7ae807b8f3b8cf"
|
source = "git+https://github.com/gfx-rs/gfx#f3d012dcfb75cfa363c4858d110a8469f002313d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ash 0.24.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"ash 0.24.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"byteorder 1.2.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"byteorder 1.2.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
@ -308,7 +308,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "gfx-hal"
|
name = "gfx-hal"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/gfx-rs/gfx#505e8057803d8cc0302b5fdcfe7ae807b8f3b8cf"
|
source = "git+https://github.com/gfx-rs/gfx#f3d012dcfb75cfa363c4858d110a8469f002313d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"bitflags 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"failure 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"failure 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
@ -666,7 +666,7 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "spirv_cross"
|
name = "spirv_cross"
|
||||||
version = "0.9.0"
|
version = "0.9.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cc 1.0.17 (registry+https://github.com/rust-lang/crates.io-index)",
|
"cc 1.0.17 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
@ -1010,7 +1010,7 @@ dependencies = [
|
||||||
"checksum shared_library 0.1.8 (registry+https://github.com/rust-lang/crates.io-index)" = "8254bf098ce4d8d7cc7cc6de438c5488adc5297e5b7ffef88816c0a91bd289c1"
|
"checksum shared_library 0.1.8 (registry+https://github.com/rust-lang/crates.io-index)" = "8254bf098ce4d8d7cc7cc6de438c5488adc5297e5b7ffef88816c0a91bd289c1"
|
||||||
"checksum smallvec 0.6.1 (registry+https://github.com/rust-lang/crates.io-index)" = "03dab98ab5ded3a8b43b2c80751194608d0b2aa0f1d46cf95d1c35e192844aa7"
|
"checksum smallvec 0.6.1 (registry+https://github.com/rust-lang/crates.io-index)" = "03dab98ab5ded3a8b43b2c80751194608d0b2aa0f1d46cf95d1c35e192844aa7"
|
||||||
"checksum spirv_cross 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)" = "387a12e5de5d5cd284d07fe7edbcac83163c0b9b4304bd3a0efb1274bcda83cf"
|
"checksum spirv_cross 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)" = "387a12e5de5d5cd284d07fe7edbcac83163c0b9b4304bd3a0efb1274bcda83cf"
|
||||||
"checksum spirv_cross 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)" = "1af833c4f35713d2d739de6e8a2a05614b25800fd48d07d98ca3a143a1df6ce1"
|
"checksum spirv_cross 0.9.2 (registry+https://github.com/rust-lang/crates.io-index)" = "e5c30addbd9ad947994bcd75019e06d09cccbe30d481f8ce6a16e1b406235b69"
|
||||||
"checksum syn 0.10.8 (registry+https://github.com/rust-lang/crates.io-index)" = "58fd09df59565db3399efbba34ba8a2fec1307511ebd245d0061ff9d42691673"
|
"checksum syn 0.10.8 (registry+https://github.com/rust-lang/crates.io-index)" = "58fd09df59565db3399efbba34ba8a2fec1307511ebd245d0061ff9d42691673"
|
||||||
"checksum syn 0.11.11 (registry+https://github.com/rust-lang/crates.io-index)" = "d3b891b9015c88c576343b9b3e41c2c11a51c219ef067b264bd9c8aa9b441dad"
|
"checksum syn 0.11.11 (registry+https://github.com/rust-lang/crates.io-index)" = "d3b891b9015c88c576343b9b3e41c2c11a51c219ef067b264bd9c8aa9b441dad"
|
||||||
"checksum synom 0.11.3 (registry+https://github.com/rust-lang/crates.io-index)" = "a393066ed9010ebaed60b9eafa373d4b1baac186dd7e008555b0f702b51945b6"
|
"checksum synom 0.11.3 (registry+https://github.com/rust-lang/crates.io-index)" = "a393066ed9010ebaed60b9eafa373d4b1baac186dd7e008555b0f702b51945b6"
|
||||||
|
|
2
Makefile
2
Makefile
|
@ -43,7 +43,7 @@ FULL_LIBRARY_PATH=$(CURDIR)/target/debug
|
||||||
LIBRARY=target/debug/libportability.$(LIB_EXTENSION)
|
LIBRARY=target/debug/libportability.$(LIB_EXTENSION)
|
||||||
LIBRARY_FAST=target/release/libportability.$(LIB_EXTENSION)
|
LIBRARY_FAST=target/release/libportability.$(LIB_EXTENSION)
|
||||||
|
|
||||||
.PHONY: all rebuild debug debug-version release binding run cts cts-pick cts-debug clean cherry
|
.PHONY: all rebuild debug debug-version release binding run cts clean cherry
|
||||||
|
|
||||||
all: $(TARGET)
|
all: $(TARGET)
|
||||||
|
|
||||||
|
|
|
@ -414,8 +414,8 @@ pub fn map_descriptor_type(ty: VkDescriptorType) -> pso::DescriptorType {
|
||||||
VK_DESCRIPTOR_TYPE_STORAGE_BUFFER => pso::DescriptorType::StorageBuffer,
|
VK_DESCRIPTOR_TYPE_STORAGE_BUFFER => pso::DescriptorType::StorageBuffer,
|
||||||
VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT => pso::DescriptorType::InputAttachment,
|
VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT => pso::DescriptorType::InputAttachment,
|
||||||
VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER => pso::DescriptorType::CombinedImageSampler,
|
VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER => pso::DescriptorType::CombinedImageSampler,
|
||||||
VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC |
|
VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC => pso::DescriptorType::UniformBufferDynamic,
|
||||||
VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC => unimplemented!(),
|
VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC => pso::DescriptorType::StorageBufferDynamic,
|
||||||
_ => panic!("Unexpected descriptor type: {:?}", ty),
|
_ => panic!("Unexpected descriptor type: {:?}", ty),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -514,18 +514,23 @@ pub fn map_polygon_mode(mode: VkPolygonMode, line_width: f32) -> pso::PolygonMod
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn map_cull_face(cull: VkCullModeFlags) -> Option<pso::CullFace> {
|
pub fn map_stencil_face(face: VkStencilFaceFlags) -> pso::Face {
|
||||||
use super::VkCullModeFlagBits::*;
|
match unsafe { mem::transmute(face) } {
|
||||||
|
VkStencilFaceFlagBits::VK_STENCIL_FACE_FRONT_BIT => pso::Face::FRONT,
|
||||||
if cull == VK_CULL_MODE_NONE as _ { None }
|
VkStencilFaceFlagBits::VK_STENCIL_FACE_BACK_BIT => pso::Face::BACK,
|
||||||
else if cull == VK_CULL_MODE_FRONT_BIT as _ { Some(pso::CullFace::Front) }
|
VkStencilFaceFlagBits::VK_STENCIL_FRONT_AND_BACK => pso::Face::all(),
|
||||||
else if cull == VK_CULL_MODE_BACK_BIT as _ { Some(pso::CullFace::Back) }
|
_ => panic!("Unexpected stencil face: {:?}", face),
|
||||||
else if cull == VK_CULL_MODE_FRONT_AND_BACK as _ {
|
}
|
||||||
// TODO: can we support it?
|
}
|
||||||
error!("VK_CULL_MODE_FRONT_AND_BACK is not supported yet");
|
|
||||||
Some(pso::CullFace::Front)
|
pub fn map_cull_face(cull: VkCullModeFlags) -> pso::Face {
|
||||||
|
match unsafe { mem::transmute(cull) } {
|
||||||
|
VkCullModeFlagBits::VK_CULL_MODE_NONE => pso::Face::empty(),
|
||||||
|
VkCullModeFlagBits::VK_CULL_MODE_FRONT_BIT => pso::Face::FRONT,
|
||||||
|
VkCullModeFlagBits::VK_CULL_MODE_BACK_BIT => pso::Face::BACK,
|
||||||
|
VkCullModeFlagBits::VK_CULL_MODE_FRONT_AND_BACK => pso::Face::all(),
|
||||||
|
_ => panic!("Unexpected cull face: {:?}", cull),
|
||||||
}
|
}
|
||||||
else { panic!("Unexpected cull mode: {:?}", cull) }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn map_front_face(face: VkFrontFace) -> pso::FrontFace {
|
pub fn map_front_face(face: VkFrontFace) -> pso::FrontFace {
|
||||||
|
|
|
@ -1307,7 +1307,13 @@ pub extern "C" fn gfxCreateImage(
|
||||||
info.samples,
|
info.samples,
|
||||||
),
|
),
|
||||||
info.mipLevels as _,
|
info.mipLevels as _,
|
||||||
conv::map_format(info.format).unwrap(),
|
match conv::map_format(info.format) {
|
||||||
|
Some(format) => format,
|
||||||
|
None => {
|
||||||
|
error!("Attempted to create an image with format {:?}", info.format);
|
||||||
|
return VkResult::VK_ERROR_OUT_OF_HOST_MEMORY
|
||||||
|
}
|
||||||
|
},
|
||||||
conv::map_tiling(info.tiling),
|
conv::map_tiling(info.tiling),
|
||||||
conv::map_image_usage(info.usage),
|
conv::map_image_usage(info.usage),
|
||||||
unsafe { mem::transmute(info.flags) },
|
unsafe { mem::transmute(info.flags) },
|
||||||
|
@ -1708,6 +1714,14 @@ pub extern "C" fn gfxCreateGraphicsPipelines(
|
||||||
None
|
None
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let empty_dyn_states = [];
|
||||||
|
let dyn_states = match unsafe { info.pDynamicState.as_ref() } {
|
||||||
|
Some(state) if !rasterizer_discard => unsafe {
|
||||||
|
slice::from_raw_parts(state.pDynamicStates, state.dynamicStateCount as _)
|
||||||
|
},
|
||||||
|
_ => &empty_dyn_states,
|
||||||
|
};
|
||||||
|
|
||||||
// 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 = if !rasterizer_discard {
|
let depth_stencil = if !rasterizer_discard {
|
||||||
|
@ -1724,12 +1738,25 @@ pub extern "C" fn gfxCreateGraphicsPipelines(
|
||||||
pso::DepthTest::Off
|
pso::DepthTest::Off
|
||||||
};
|
};
|
||||||
|
|
||||||
fn map_stencil_state(state: VkStencilOpState) -> pso::StencilFace {
|
fn map_stencil_state(state: VkStencilOpState, dyn_states: &[VkDynamicState]) -> pso::StencilFace {
|
||||||
// TODO: reference value
|
// TODO: reference value
|
||||||
pso::StencilFace {
|
pso::StencilFace {
|
||||||
fun: conv::map_compare_op(state.compareOp),
|
fun: conv::map_compare_op(state.compareOp),
|
||||||
mask_read: state.compareMask,
|
mask_read: if dyn_states.iter().any(|&ds| ds == VkDynamicState::VK_DYNAMIC_STATE_STENCIL_COMPARE_MASK) {
|
||||||
mask_write: state.writeMask,
|
pso::State::Dynamic
|
||||||
|
} else {
|
||||||
|
pso::State::Static(state.compareMask)
|
||||||
|
},
|
||||||
|
mask_write: if dyn_states.iter().any(|&ds| ds == VkDynamicState::VK_DYNAMIC_STATE_STENCIL_WRITE_MASK) {
|
||||||
|
pso::State::Dynamic
|
||||||
|
} else {
|
||||||
|
pso::State::Static(state.writeMask)
|
||||||
|
},
|
||||||
|
reference: if dyn_states.iter().any(|&ds| ds == VkDynamicState::VK_DYNAMIC_STATE_STENCIL_REFERENCE) {
|
||||||
|
pso::State::Dynamic
|
||||||
|
} else {
|
||||||
|
pso::State::Static(state.reference)
|
||||||
|
},
|
||||||
op_fail: conv::map_stencil_op(state.failOp),
|
op_fail: conv::map_stencil_op(state.failOp),
|
||||||
op_depth_fail: conv::map_stencil_op(state.depthFailOp),
|
op_depth_fail: conv::map_stencil_op(state.depthFailOp),
|
||||||
op_pass: conv::map_stencil_op(state.passOp),
|
op_pass: conv::map_stencil_op(state.passOp),
|
||||||
|
@ -1738,8 +1765,8 @@ pub extern "C" fn gfxCreateGraphicsPipelines(
|
||||||
|
|
||||||
let stencil_test = if state.stencilTestEnable == VK_TRUE {
|
let stencil_test = if state.stencilTestEnable == VK_TRUE {
|
||||||
pso::StencilTest::On {
|
pso::StencilTest::On {
|
||||||
front: map_stencil_state(state.front),
|
front: map_stencil_state(state.front, &dyn_states),
|
||||||
back: map_stencil_state(state.back),
|
back: map_stencil_state(state.back, &dyn_states),
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
pso::StencilTest::Off
|
pso::StencilTest::Off
|
||||||
|
@ -1753,9 +1780,10 @@ pub extern "C" fn gfxCreateGraphicsPipelines(
|
||||||
stencil: stencil_test,
|
stencil: stencil_test,
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
.unwrap_or_default()
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
None
|
pso::DepthStencilDesc::default()
|
||||||
};
|
};
|
||||||
|
|
||||||
let vp_state = if !rasterizer_discard {
|
let vp_state = if !rasterizer_discard {
|
||||||
|
@ -1763,13 +1791,6 @@ pub extern "C" fn gfxCreateGraphicsPipelines(
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
};
|
};
|
||||||
let empty_dyn_states = [];
|
|
||||||
let dyn_states = match unsafe { info.pDynamicState.as_ref() } {
|
|
||||||
Some(state) if !rasterizer_discard => unsafe {
|
|
||||||
slice::from_raw_parts(state.pDynamicStates, state.dynamicStateCount as _)
|
|
||||||
},
|
|
||||||
_ => &empty_dyn_states,
|
|
||||||
};
|
|
||||||
let baked_states = pso::BakedStates {
|
let baked_states = pso::BakedStates {
|
||||||
viewport: if dyn_states.iter().any(|&ds| ds == VkDynamicState::VK_DYNAMIC_STATE_VIEWPORT) {
|
viewport: if dyn_states.iter().any(|&ds| ds == VkDynamicState::VK_DYNAMIC_STATE_VIEWPORT) {
|
||||||
None
|
None
|
||||||
|
@ -2260,8 +2281,7 @@ pub extern "C" fn gfxUpdateDescriptorSets(
|
||||||
}
|
}
|
||||||
pso::DescriptorType::InputAttachment |
|
pso::DescriptorType::InputAttachment |
|
||||||
pso::DescriptorType::SampledImage |
|
pso::DescriptorType::SampledImage |
|
||||||
pso::DescriptorType::StorageImage |
|
pso::DescriptorType::StorageImage => {
|
||||||
pso::DescriptorType::UniformImageDynamic => {
|
|
||||||
image_info
|
image_info
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|image| pso::Descriptor::Image(
|
.map(|image| pso::Descriptor::Image(
|
||||||
|
@ -2288,7 +2308,8 @@ pub extern "C" fn gfxUpdateDescriptorSets(
|
||||||
}
|
}
|
||||||
pso::DescriptorType::UniformBuffer |
|
pso::DescriptorType::UniformBuffer |
|
||||||
pso::DescriptorType::StorageBuffer |
|
pso::DescriptorType::StorageBuffer |
|
||||||
pso::DescriptorType::UniformBufferDynamic => {
|
pso::DescriptorType::UniformBufferDynamic |
|
||||||
|
pso::DescriptorType::StorageBufferDynamic => {
|
||||||
buffer_info
|
buffer_info
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|buffer| {
|
.map(|buffer| {
|
||||||
|
@ -2470,7 +2491,7 @@ pub extern "C" fn gfxCreateRenderPass(
|
||||||
subpass
|
subpass
|
||||||
.pDepthStencilAttachment
|
.pDepthStencilAttachment
|
||||||
.as_ref()
|
.as_ref()
|
||||||
.map(|attachment| map_attachment_ref(attachment))
|
.map(map_attachment_ref)
|
||||||
};
|
};
|
||||||
|
|
||||||
let preserve = unsafe {
|
let preserve = unsafe {
|
||||||
|
@ -2781,7 +2802,7 @@ pub extern "C" fn gfxCmdSetStencilCompareMask(
|
||||||
_faceMask: VkStencilFaceFlags,
|
_faceMask: VkStencilFaceFlags,
|
||||||
_compareMask: u32,
|
_compareMask: u32,
|
||||||
) {
|
) {
|
||||||
unimplemented!()
|
error!("gfxCmdSetStencilCompareMask not implemented");
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxCmdSetStencilWriteMask(
|
pub extern "C" fn gfxCmdSetStencilWriteMask(
|
||||||
|
@ -2789,15 +2810,18 @@ pub extern "C" fn gfxCmdSetStencilWriteMask(
|
||||||
_faceMask: VkStencilFaceFlags,
|
_faceMask: VkStencilFaceFlags,
|
||||||
_writeMask: u32,
|
_writeMask: u32,
|
||||||
) {
|
) {
|
||||||
unimplemented!()
|
error!("gfxCmdSetStencilWriteMask not implemented");
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxCmdSetStencilReference(
|
pub extern "C" fn gfxCmdSetStencilReference(
|
||||||
_commandBuffer: VkCommandBuffer,
|
mut commandBuffer: VkCommandBuffer,
|
||||||
_faceMask: VkStencilFaceFlags,
|
faceMask: VkStencilFaceFlags,
|
||||||
_reference: u32,
|
reference: u32,
|
||||||
) {
|
) {
|
||||||
unimplemented!()
|
commandBuffer.set_stencil_reference(
|
||||||
|
conv::map_stencil_face(faceMask),
|
||||||
|
reference,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
#[inline]
|
#[inline]
|
||||||
pub extern "C" fn gfxCmdBindDescriptorSets(
|
pub extern "C" fn gfxCmdBindDescriptorSets(
|
||||||
|
@ -2810,14 +2834,14 @@ pub extern "C" fn gfxCmdBindDescriptorSets(
|
||||||
dynamicOffsetCount: u32,
|
dynamicOffsetCount: u32,
|
||||||
pDynamicOffsets: *const u32,
|
pDynamicOffsets: *const u32,
|
||||||
) {
|
) {
|
||||||
assert_eq!(dynamicOffsetCount, 0); // TODO
|
|
||||||
let _ = pDynamicOffsets;
|
|
||||||
|
|
||||||
let descriptor_sets = unsafe {
|
let descriptor_sets = unsafe {
|
||||||
slice::from_raw_parts(pDescriptorSets, descriptorSetCount as _)
|
slice::from_raw_parts(pDescriptorSets, descriptorSetCount as _)
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|set| &**set)
|
.map(|set| &**set)
|
||||||
};
|
};
|
||||||
|
let offsets = unsafe {
|
||||||
|
slice::from_raw_parts(pDynamicOffsets, dynamicOffsetCount as _)
|
||||||
|
};
|
||||||
|
|
||||||
match pipelineBindPoint {
|
match pipelineBindPoint {
|
||||||
VkPipelineBindPoint::VK_PIPELINE_BIND_POINT_GRAPHICS => {
|
VkPipelineBindPoint::VK_PIPELINE_BIND_POINT_GRAPHICS => {
|
||||||
|
@ -2825,6 +2849,7 @@ pub extern "C" fn gfxCmdBindDescriptorSets(
|
||||||
&*layout,
|
&*layout,
|
||||||
firstSet as _,
|
firstSet as _,
|
||||||
descriptor_sets,
|
descriptor_sets,
|
||||||
|
offsets,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
VkPipelineBindPoint::VK_PIPELINE_BIND_POINT_COMPUTE => {
|
VkPipelineBindPoint::VK_PIPELINE_BIND_POINT_COMPUTE => {
|
||||||
|
@ -2832,6 +2857,7 @@ pub extern "C" fn gfxCmdBindDescriptorSets(
|
||||||
&*layout,
|
&*layout,
|
||||||
firstSet as _,
|
firstSet as _,
|
||||||
descriptor_sets,
|
descriptor_sets,
|
||||||
|
offsets,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
_ => panic!("Unexpected pipeline bind point: {:?}", pipelineBindPoint),
|
_ => panic!("Unexpected pipeline bind point: {:?}", pipelineBindPoint),
|
||||||
|
@ -3198,22 +3224,19 @@ pub extern "C" fn gfxCmdClearAttachments(
|
||||||
attachments.iter().map(|at| {
|
attachments.iter().map(|at| {
|
||||||
use VkImageAspectFlagBits::*;
|
use VkImageAspectFlagBits::*;
|
||||||
if at.aspectMask & VK_IMAGE_ASPECT_COLOR_BIT as u32 != 0 {
|
if at.aspectMask & VK_IMAGE_ASPECT_COLOR_BIT as u32 != 0 {
|
||||||
com::AttachmentClear::Color(
|
com::AttachmentClear::Color {
|
||||||
at.colorAttachment as _,
|
index: at.colorAttachment as _,
|
||||||
unsafe { at.clearValue.color.float32 }.into(), //TODO!
|
value: unsafe { at.clearValue.color.float32 }.into(), //TODO?
|
||||||
)
|
}
|
||||||
} else
|
|
||||||
if at.aspectMask & VK_IMAGE_ASPECT_DEPTH_BIT as u32 != 0 {
|
|
||||||
com::AttachmentClear::Depth(unsafe {
|
|
||||||
at.clearValue.depthStencil.depth
|
|
||||||
})
|
|
||||||
} else
|
|
||||||
if at.aspectMask & VK_IMAGE_ASPECT_STENCIL_BIT as u32 != 0 {
|
|
||||||
com::AttachmentClear::Stencil(unsafe {
|
|
||||||
at.clearValue.depthStencil.stencil
|
|
||||||
})
|
|
||||||
} else {
|
} else {
|
||||||
panic!("Unexpected mask {:?}", at.aspectMask);
|
com::AttachmentClear::DepthStencil {
|
||||||
|
depth: if at.aspectMask & VK_IMAGE_ASPECT_DEPTH_BIT as u32 != 0 {
|
||||||
|
Some(unsafe { at.clearValue.depthStencil.depth })
|
||||||
|
} else { None },
|
||||||
|
stencil: if at.aspectMask & VK_IMAGE_ASPECT_STENCIL_BIT as u32 != 0 {
|
||||||
|
Some(unsafe { at.clearValue.depthStencil.stencil })
|
||||||
|
} else { None },
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
rects.iter().map(conv::map_clear_rect),
|
rects.iter().map(conv::map_clear_rect),
|
||||||
|
|
Loading…
Reference in a new issue