4 releases

0.2.0 Sep 28, 2024
0.1.2 Aug 28, 2024
0.1.1 Aug 28, 2024
0.1.0 Aug 28, 2024

#135 in Graphics APIs

Download history 898/week @ 2024-09-07 1269/week @ 2024-09-14 1220/week @ 2024-09-21 1175/week @ 2024-09-28 701/week @ 2024-10-05 197/week @ 2024-10-12 193/week @ 2024-10-19 348/week @ 2024-10-26 553/week @ 2024-11-02 471/week @ 2024-11-09 583/week @ 2024-11-16 215/week @ 2024-11-23 345/week @ 2024-11-30 181/week @ 2024-12-07 235/week @ 2024-12-14 180/week @ 2024-12-21

981 downloads per month
Used in 4 crates (2 directly)

MIT/Apache

20KB
295 lines

d3d12-descriptor-heap

A simple to use descriptor heap for Direct3D 12, using the windows crate.

Usage

Declare ZST structs for each heap type, and implement D3D12DescriptorHeapType for it.

#[derive(Clone)]
pub struct CpuStagingHeap;

impl D3D12DescriptorHeapType for CpuStagingHeap {
    fn create_desc(size: usize) -> D3D12_DESCRIPTOR_HEAP_DESC {
        D3D12_DESCRIPTOR_HEAP_DESC {
            Type: D3D12_DESCRIPTOR_HEAP_TYPE_CBV_SRV_UAV,
            NumDescriptors: size as u32,
            Flags: D3D12_DESCRIPTOR_HEAP_FLAG_NONE,
            NodeMask: 0,
        }
    }
}

Then create the heap and hand out ref-counted handles to slots in the heap. The slot will be freed on drop.

fn create_heap(device: &ID3D12Device) -> Result<(), D3D12DescriptorHeapError> {
    let heap = D3D12DescriptorHeap::<CpuStagingHeap>::new(device, 10);
    let slot = heap.allocate_descriptor()?;
}

Heap slots implement AsRef<D3D12_CPU_DESCRIPTOR_HANDLE> so they can be passed directly into Direct3D 12 APIs that take D3D12_CPU_DESCRIPTOR_HANDLE. For shader-visible heaps, implement D3D12ShaderVisibleDescriptorHeapType for the heap type.

#[derive(Clone)]
pub struct SamplerHeap;

impl D3D12DescriptorHeapType for SamplerHeap {
    fn create_desc(size: usize) -> D3D12_DESCRIPTOR_HEAP_DESC {
        D3D12_DESCRIPTOR_HEAP_DESC {
            Type: D3D12_DESCRIPTOR_HEAP_TYPE_SAMPLER,
            NumDescriptors: size as u32,
            Flags: D3D12_DESCRIPTOR_HEAP_FLAG_SHADER_VISIBLE,
            NodeMask: 0,
        }
    }
}

unsafe impl D3D12ShaderVisibleDescriptorHeapType for SamplerHeap {}

Heap slots that are allocated for a heap type implementing D3D12ShaderVisibleDescriptorHeapType also implement AsRef<D3D12_GPU_DESCRIPTOR_HANDLE>.

Dependencies

~1–37MB
~566K SLoC