Skip to content

Commit

Permalink
Add setter for VirtualBlockInfo::flag (#3)
Browse files Browse the repository at this point in the history
  • Loading branch information
aka-deVOID authored Jun 18, 2023
1 parent f327969 commit f77d06d
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 15 deletions.
10 changes: 6 additions & 4 deletions src/definitions.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@ use ash::vk;
use ash::vk::PhysicalDevice;
use ash::{Device, Instance};
use bitflags::bitflags;
use std::ptr;
use std::marker::PhantomData;
use std::ptr;

/// Intended usage of memory.
#[derive(Debug, Clone, Copy, Eq, PartialEq, Hash, PartialOrd, Ord)]
Expand Down Expand Up @@ -672,8 +672,6 @@ impl From<ffi::VmaAllocationInfo> for AllocationInfo {
}
}



bitflags! {
/// Flags for configuring `VirtualBlock` construction
pub struct VirtualBlockCreateFlags: u32 {
Expand Down Expand Up @@ -773,6 +771,11 @@ impl<'a> VirtualBlockCreateInfo<'a> {
self.inner.size = size;
self
}

pub fn flag(mut self, flag: VirtualAllocationCreateFlags) -> Self {
self.inner.flags = flag.bits;
self
}
}

impl From<&ffi::VmaVirtualAllocationInfo> for VirtualAllocationInfo {
Expand Down Expand Up @@ -806,4 +809,3 @@ impl From<VirtualAllocationCreateInfo> for ffi::VmaVirtualAllocationCreateInfo {
(&info).into()
}
}

21 changes: 10 additions & 11 deletions tests/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -296,16 +296,16 @@ fn test_gpu_stats() {

#[test]
fn create_virtual_block() {
let create_info = vma::VirtualBlockCreateInfo::new().size(16 * 1024 * 1024); // 16MB block
let _virtual_block = vma::VirtualBlock::new(create_info)
.expect("Couldn't create VirtualBlock");
let create_info = vma::VirtualBlockCreateInfo::new()
.size(16 * 1024 * 1024)
.flag(vma::VirtualAllocationCreateFlags::VMA_VIRTUAL_ALLOCATION_CREATE_STRATEGY_MASK); // 16MB block
let _virtual_block = vma::VirtualBlock::new(create_info).expect("Couldn't create VirtualBlock");
}

#[test]
fn virtual_allocate_and_free() {
let create_info = vma::VirtualBlockCreateInfo::new().size(16 * 1024 * 1024); // 16MB block
let virtual_block = vma::VirtualBlock::new(create_info)
.expect("Couldn't create VirtualBlock");
let virtual_block = vma::VirtualBlock::new(create_info).expect("Couldn't create VirtualBlock");

let allocation_info = vma::VirtualAllocationCreateInfo {
size: 8 * 1024 * 1024,
Expand Down Expand Up @@ -338,8 +338,7 @@ fn virtual_allocate_and_free() {
#[test]
fn virtual_allocation_user_data() {
let create_info = vma::VirtualBlockCreateInfo::new().size(16 * 1024 * 1024); // 16MB block
let virtual_block = vma::VirtualBlock::new(create_info)
.expect("Couldn't create VirtualBlock");
let virtual_block = vma::VirtualBlock::new(create_info).expect("Couldn't create VirtualBlock");

let user_data = Box::new(vec![12, 34, 56, 78, 90]);
let allocation_info = vma::VirtualAllocationCreateInfo {
Expand All @@ -351,7 +350,8 @@ fn virtual_allocation_user_data() {

unsafe {
let (virtual_alloc_0, _) = virtual_block.allocate(allocation_info).unwrap();
let queried_info = virtual_block.get_allocation_info(&virtual_alloc_0)
let queried_info = virtual_block
.get_allocation_info(&virtual_alloc_0)
.expect("Couldn't get VirtualAllocationInfo from VirtualBlock");
let queried_user_data = std::slice::from_raw_parts(queried_info.user_data as *const i32, 5);
assert_eq!(queried_user_data, &*user_data);
Expand All @@ -362,8 +362,7 @@ fn virtual_allocation_user_data() {
#[test]
fn virtual_block_out_of_space() {
let create_info = vma::VirtualBlockCreateInfo::new().size(16 * 1024 * 1024); // 16MB block
let virtual_block = vma::VirtualBlock::new(create_info)
.expect("Couldn't create VirtualBlock");
let virtual_block = vma::VirtualBlock::new(create_info).expect("Couldn't create VirtualBlock");

let allocation_info = vma::VirtualAllocationCreateInfo {
size: 16 * 1024 * 1024 + 1,
Expand All @@ -375,7 +374,7 @@ fn virtual_block_out_of_space() {
unsafe {
match virtual_block.allocate(allocation_info) {
Ok(_) => panic!("Created VirtualAllocation larger than VirtualBlock"),
Err(ash::vk::Result::ERROR_OUT_OF_DEVICE_MEMORY) => {},
Err(ash::vk::Result::ERROR_OUT_OF_DEVICE_MEMORY) => {}
Err(_) => panic!("Unexpected VirtualBlock error"),
}
}
Expand Down

0 comments on commit f77d06d

Please sign in to comment.