rt: clean up sampler sets
This commit is contained in:
parent
302ef76a82
commit
8ed244f6fa
|
@ -137,7 +137,6 @@ impl FilterChainD3D11 {
|
||||||
|
|
||||||
// initialize passes
|
// initialize passes
|
||||||
let filters = FilterChainD3D11::init_passes(device, passes, &semantics, disable_cache)?;
|
let filters = FilterChainD3D11::init_passes(device, passes, &semantics, disable_cache)?;
|
||||||
println!("passes loded");
|
|
||||||
|
|
||||||
let immediate_context = unsafe { device.GetImmediateContext()? };
|
let immediate_context = unsafe { device.GetImmediateContext()? };
|
||||||
|
|
||||||
|
@ -165,7 +164,6 @@ impl FilterChainD3D11 {
|
||||||
|
|
||||||
let draw_quad = DrawQuad::new(device)?;
|
let draw_quad = DrawQuad::new(device)?;
|
||||||
let state = D3D11State::new(device)?;
|
let state = D3D11State::new(device)?;
|
||||||
println!("ready");
|
|
||||||
Ok(FilterChainD3D11 {
|
Ok(FilterChainD3D11 {
|
||||||
passes: filters,
|
passes: filters,
|
||||||
output_framebuffers,
|
output_framebuffers,
|
||||||
|
|
|
@ -10,9 +10,15 @@ pub struct SamplerSet {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SamplerSet {
|
impl SamplerSet {
|
||||||
|
#[inline(always)]
|
||||||
pub fn get(&self, wrap: WrapMode, filter: FilterMode) -> &ID3D11SamplerState {
|
pub fn get(&self, wrap: WrapMode, filter: FilterMode) -> &ID3D11SamplerState {
|
||||||
self.samplers.get(&(wrap, filter)).unwrap()
|
// SAFETY: the sampler set is complete for the matrix
|
||||||
|
// wrap x filter
|
||||||
|
unsafe {
|
||||||
|
self.samplers.get(&(wrap, filter)).unwrap_unchecked()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new(device: &ID3D11Device) -> Result<SamplerSet> {
|
pub fn new(device: &ID3D11Device) -> Result<SamplerSet> {
|
||||||
let mut samplers = FxHashMap::default();
|
let mut samplers = FxHashMap::default();
|
||||||
let wrap_modes = &[
|
let wrap_modes = &[
|
||||||
|
@ -22,49 +28,32 @@ impl SamplerSet {
|
||||||
WrapMode::MirroredRepeat,
|
WrapMode::MirroredRepeat,
|
||||||
];
|
];
|
||||||
for wrap_mode in wrap_modes {
|
for wrap_mode in wrap_modes {
|
||||||
unsafe {
|
for filter_mode in &[FilterMode::Linear, FilterMode::Nearest] {
|
||||||
let mut linear = None;
|
unsafe {
|
||||||
device.CreateSamplerState(
|
let mut sampler = None;
|
||||||
&D3D11_SAMPLER_DESC {
|
device.CreateSamplerState(
|
||||||
Filter: FilterMode::Linear.into(),
|
&D3D11_SAMPLER_DESC {
|
||||||
AddressU: D3D11_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
Filter: FilterMode::Linear.into(),
|
||||||
AddressV: D3D11_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
AddressU: D3D11_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
||||||
AddressW: D3D11_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
AddressV: D3D11_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
||||||
MipLODBias: 0.0,
|
AddressW: D3D11_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
||||||
MaxAnisotropy: 1,
|
MipLODBias: 0.0,
|
||||||
ComparisonFunc: D3D11_COMPARISON_NEVER,
|
MaxAnisotropy: 1,
|
||||||
BorderColor: [0.0, 0.0, 0.0, 0.0],
|
ComparisonFunc: D3D11_COMPARISON_NEVER,
|
||||||
MinLOD: -D3D11_FLOAT32_MAX,
|
BorderColor: [0.0, 0.0, 0.0, 0.0],
|
||||||
MaxLOD: D3D11_FLOAT32_MAX,
|
MinLOD: -D3D11_FLOAT32_MAX,
|
||||||
},
|
MaxLOD: D3D11_FLOAT32_MAX,
|
||||||
Some(&mut linear),
|
},
|
||||||
)?;
|
Some(&mut sampler),
|
||||||
|
)?;
|
||||||
|
|
||||||
assume_d3d11_init!(linear, "CreateSamplerState");
|
assume_d3d11_init!(sampler, "CreateSamplerState");
|
||||||
|
samplers.insert((*wrap_mode, *filter_mode), sampler);
|
||||||
let mut nearest = None;
|
}
|
||||||
device.CreateSamplerState(
|
|
||||||
&D3D11_SAMPLER_DESC {
|
|
||||||
Filter: FilterMode::Nearest.into(),
|
|
||||||
AddressU: D3D11_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
|
||||||
AddressV: D3D11_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
|
||||||
AddressW: D3D11_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
|
||||||
MipLODBias: 0.0,
|
|
||||||
MaxAnisotropy: 1,
|
|
||||||
ComparisonFunc: D3D11_COMPARISON_NEVER,
|
|
||||||
BorderColor: [0.0, 0.0, 0.0, 0.0],
|
|
||||||
MinLOD: -D3D11_FLOAT32_MAX,
|
|
||||||
MaxLOD: D3D11_FLOAT32_MAX,
|
|
||||||
},
|
|
||||||
Some(&mut nearest),
|
|
||||||
)?;
|
|
||||||
assume_d3d11_init!(nearest, "CreateSamplerState");
|
|
||||||
|
|
||||||
samplers.insert((*wrap_mode, FilterMode::Linear), linear);
|
|
||||||
samplers.insert((*wrap_mode, FilterMode::Nearest), nearest);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
assert_eq!(samplers.len(), wrap_modes.len() * 2);
|
||||||
Ok(SamplerSet { samplers })
|
Ok(SamplerSet { samplers })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
use std::iter::Filter;
|
||||||
use crate::descriptor_heap::{D3D12DescriptorHeap, D3D12DescriptorHeapSlot, SamplerPaletteHeap};
|
use crate::descriptor_heap::{D3D12DescriptorHeap, D3D12DescriptorHeapSlot, SamplerPaletteHeap};
|
||||||
use crate::error;
|
use crate::error;
|
||||||
use librashader_common::{FilterMode, WrapMode};
|
use librashader_common::{FilterMode, WrapMode};
|
||||||
|
@ -14,12 +15,17 @@ pub struct SamplerSet {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SamplerSet {
|
impl SamplerSet {
|
||||||
|
#[inline(always)]
|
||||||
pub fn get(
|
pub fn get(
|
||||||
&self,
|
&self,
|
||||||
wrap: WrapMode,
|
wrap: WrapMode,
|
||||||
filter: FilterMode,
|
filter: FilterMode,
|
||||||
) -> &D3D12DescriptorHeapSlot<SamplerPaletteHeap> {
|
) -> &D3D12DescriptorHeapSlot<SamplerPaletteHeap> {
|
||||||
self.samplers.get(&(wrap, filter)).unwrap()
|
// SAFETY: the sampler set is complete for the matrix
|
||||||
|
// wrap x filter
|
||||||
|
unsafe {
|
||||||
|
self.samplers.get(&(wrap, filter)).unwrap_unchecked()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
pub fn new(device: &ID3D12Device) -> error::Result<SamplerSet> {
|
pub fn new(device: &ID3D12Device) -> error::Result<SamplerSet> {
|
||||||
let mut samplers = FxHashMap::default();
|
let mut samplers = FxHashMap::default();
|
||||||
|
@ -33,46 +39,30 @@ impl SamplerSet {
|
||||||
let mut heap = D3D12DescriptorHeap::new(device, 2 * wrap_modes.len())?;
|
let mut heap = D3D12DescriptorHeap::new(device, 2 * wrap_modes.len())?;
|
||||||
|
|
||||||
for wrap_mode in wrap_modes {
|
for wrap_mode in wrap_modes {
|
||||||
unsafe {
|
for filter_mode in &[FilterMode::Linear, FilterMode::Nearest] {
|
||||||
let linear = heap.alloc_slot()?;
|
unsafe {
|
||||||
device.CreateSampler(
|
let sampler = heap.alloc_slot()?;
|
||||||
&D3D12_SAMPLER_DESC {
|
device.CreateSampler(
|
||||||
Filter: FilterMode::Linear.into(),
|
&D3D12_SAMPLER_DESC {
|
||||||
AddressU: D3D12_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
Filter: FilterMode::Linear.into(),
|
||||||
AddressV: D3D12_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
AddressU: D3D12_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
||||||
AddressW: D3D12_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
AddressV: D3D12_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
||||||
MipLODBias: 0.0,
|
AddressW: D3D12_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
||||||
MaxAnisotropy: 1,
|
MipLODBias: 0.0,
|
||||||
ComparisonFunc: D3D12_COMPARISON_FUNC_NEVER,
|
MaxAnisotropy: 1,
|
||||||
BorderColor: [0.0, 0.0, 0.0, 0.0],
|
ComparisonFunc: D3D12_COMPARISON_FUNC_NEVER,
|
||||||
MinLOD: -D3D12_FLOAT32_MAX,
|
BorderColor: [0.0, 0.0, 0.0, 0.0],
|
||||||
MaxLOD: D3D12_FLOAT32_MAX,
|
MinLOD: -D3D12_FLOAT32_MAX,
|
||||||
},
|
MaxLOD: D3D12_FLOAT32_MAX,
|
||||||
*linear.deref().as_ref(),
|
},
|
||||||
);
|
*sampler.deref().as_ref(),
|
||||||
|
);
|
||||||
let nearest = heap.alloc_slot()?;
|
samplers.insert((*wrap_mode, *filter_mode), sampler);
|
||||||
device.CreateSampler(
|
}
|
||||||
&D3D12_SAMPLER_DESC {
|
|
||||||
Filter: FilterMode::Nearest.into(),
|
|
||||||
AddressU: D3D12_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
|
||||||
AddressV: D3D12_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
|
||||||
AddressW: D3D12_TEXTURE_ADDRESS_MODE::from(*wrap_mode),
|
|
||||||
MipLODBias: 0.0,
|
|
||||||
MaxAnisotropy: 1,
|
|
||||||
ComparisonFunc: D3D12_COMPARISON_FUNC_NEVER,
|
|
||||||
BorderColor: [0.0, 0.0, 0.0, 0.0],
|
|
||||||
MinLOD: -D3D12_FLOAT32_MAX,
|
|
||||||
MaxLOD: D3D12_FLOAT32_MAX,
|
|
||||||
},
|
|
||||||
*nearest.deref().as_ref(),
|
|
||||||
);
|
|
||||||
|
|
||||||
samplers.insert((*wrap_mode, FilterMode::Linear), linear);
|
|
||||||
samplers.insert((*wrap_mode, FilterMode::Nearest), nearest);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
assert_eq!(samplers.len(), wrap_modes.len() * 2);
|
||||||
Ok(SamplerSet {
|
Ok(SamplerSet {
|
||||||
samplers,
|
samplers,
|
||||||
_heap: heap,
|
_heap: heap,
|
||||||
|
|
|
@ -8,9 +8,13 @@ pub struct SamplerSet {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SamplerSet {
|
impl SamplerSet {
|
||||||
|
#[inline(always)]
|
||||||
pub fn get(&self, wrap: WrapMode, filter: FilterMode, mipmap: FilterMode) -> GLuint {
|
pub fn get(&self, wrap: WrapMode, filter: FilterMode, mipmap: FilterMode) -> GLuint {
|
||||||
// eprintln!("{wrap}, {filter}, {mip}");
|
// SAFETY: the sampler set is complete for the matrix
|
||||||
*self.samplers.get(&(wrap, filter, mipmap)).unwrap()
|
// wrap x filter x mipmap
|
||||||
|
unsafe {
|
||||||
|
*self.samplers.get(&(wrap, filter, mipmap)).unwrap_unchecked()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn make_sampler(sampler: GLuint, wrap: WrapMode, filter: FilterMode, mip: FilterMode) {
|
fn make_sampler(sampler: GLuint, wrap: WrapMode, filter: FilterMode, mip: FilterMode) {
|
||||||
|
@ -36,62 +40,29 @@ impl SamplerSet {
|
||||||
WrapMode::MirroredRepeat,
|
WrapMode::MirroredRepeat,
|
||||||
];
|
];
|
||||||
for wrap_mode in wrap_modes {
|
for wrap_mode in wrap_modes {
|
||||||
unsafe {
|
for filter_mode in &[FilterMode::Linear, FilterMode::Nearest] {
|
||||||
let mut linear_linear = 0;
|
for mip_filter in &[FilterMode::Linear, FilterMode::Nearest] {
|
||||||
let mut linear_nearest = 0;
|
let mut sampler = 0;
|
||||||
|
unsafe {
|
||||||
|
gl::GenSamplers(1, &mut sampler);
|
||||||
|
SamplerSet::make_sampler(
|
||||||
|
sampler,
|
||||||
|
*wrap_mode,
|
||||||
|
*filter_mode,
|
||||||
|
*mip_filter,
|
||||||
|
);
|
||||||
|
|
||||||
let mut nearest_nearest = 0;
|
samplers.insert(
|
||||||
let mut nearest_linear = 0;
|
(*wrap_mode, *filter_mode, *mip_filter),
|
||||||
gl::GenSamplers(1, &mut linear_linear);
|
sampler,
|
||||||
gl::GenSamplers(1, &mut linear_nearest);
|
);
|
||||||
gl::GenSamplers(1, &mut nearest_linear);
|
}
|
||||||
gl::GenSamplers(1, &mut nearest_nearest);
|
}
|
||||||
|
|
||||||
SamplerSet::make_sampler(
|
|
||||||
linear_linear,
|
|
||||||
*wrap_mode,
|
|
||||||
FilterMode::Linear,
|
|
||||||
FilterMode::Linear,
|
|
||||||
);
|
|
||||||
SamplerSet::make_sampler(
|
|
||||||
linear_nearest,
|
|
||||||
*wrap_mode,
|
|
||||||
FilterMode::Linear,
|
|
||||||
FilterMode::Nearest,
|
|
||||||
);
|
|
||||||
SamplerSet::make_sampler(
|
|
||||||
nearest_linear,
|
|
||||||
*wrap_mode,
|
|
||||||
FilterMode::Nearest,
|
|
||||||
FilterMode::Linear,
|
|
||||||
);
|
|
||||||
SamplerSet::make_sampler(
|
|
||||||
nearest_nearest,
|
|
||||||
*wrap_mode,
|
|
||||||
FilterMode::Nearest,
|
|
||||||
FilterMode::Nearest,
|
|
||||||
);
|
|
||||||
|
|
||||||
samplers.insert(
|
|
||||||
(*wrap_mode, FilterMode::Linear, FilterMode::Linear),
|
|
||||||
linear_linear,
|
|
||||||
);
|
|
||||||
samplers.insert(
|
|
||||||
(*wrap_mode, FilterMode::Linear, FilterMode::Nearest),
|
|
||||||
linear_nearest,
|
|
||||||
);
|
|
||||||
|
|
||||||
samplers.insert(
|
|
||||||
(*wrap_mode, FilterMode::Nearest, FilterMode::Nearest),
|
|
||||||
nearest_nearest,
|
|
||||||
);
|
|
||||||
samplers.insert(
|
|
||||||
(*wrap_mode, FilterMode::Nearest, FilterMode::Linear),
|
|
||||||
nearest_linear,
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// assert all samplers were created.
|
||||||
|
assert_eq!(samplers.len(), wrap_modes.len() * 2 * 2);
|
||||||
SamplerSet { samplers }
|
SamplerSet { samplers }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -515,9 +515,11 @@ void main()
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
filter
|
unsafe {
|
||||||
.frame(&rendered, &viewport, framecount, None)
|
filter
|
||||||
.unwrap();
|
.frame(&rendered, &viewport, framecount, None)
|
||||||
|
.unwrap();
|
||||||
|
}
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
// texture is done now.
|
// texture is done now.
|
||||||
|
|
|
@ -509,9 +509,11 @@ void main()
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
filter
|
unsafe {
|
||||||
.frame(&rendered, &viewport, framecount, None)
|
filter
|
||||||
.unwrap();
|
.frame(&rendered, &viewport, framecount, None)
|
||||||
|
.unwrap();
|
||||||
|
}
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
// texture is done now.
|
// texture is done now.
|
||||||
|
|
|
@ -56,9 +56,14 @@ pub struct SamplerSet {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SamplerSet {
|
impl SamplerSet {
|
||||||
|
#[inline(always)]
|
||||||
pub fn get(&self, wrap: WrapMode, filter: FilterMode, mipmap: FilterMode) -> &VulkanSampler {
|
pub fn get(&self, wrap: WrapMode, filter: FilterMode, mipmap: FilterMode) -> &VulkanSampler {
|
||||||
// eprintln!("{wrap}, {filter}, {mip}");
|
// eprintln!("{wrap}, {filter}, {mip}");
|
||||||
self.samplers.get(&(wrap, filter, mipmap)).unwrap()
|
// SAFETY: the sampler set is complete for the matrix
|
||||||
|
// wrap x filter x mipmap
|
||||||
|
unsafe {
|
||||||
|
self.samplers.get(&(wrap, filter, mipmap)).unwrap_unchecked()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new(device: &Arc<ash::Device>) -> error::Result<SamplerSet> {
|
pub fn new(device: &Arc<ash::Device>) -> error::Result<SamplerSet> {
|
||||||
|
@ -70,25 +75,18 @@ impl SamplerSet {
|
||||||
WrapMode::MirroredRepeat,
|
WrapMode::MirroredRepeat,
|
||||||
];
|
];
|
||||||
for wrap_mode in wrap_modes {
|
for wrap_mode in wrap_modes {
|
||||||
samplers.insert(
|
for filter_mode in &[FilterMode::Linear, FilterMode::Nearest] {
|
||||||
(*wrap_mode, FilterMode::Linear, FilterMode::Linear),
|
for mipmap_filter in &[FilterMode::Linear, FilterMode::Nearest] {
|
||||||
VulkanSampler::new(device, *wrap_mode, FilterMode::Linear, FilterMode::Linear)?,
|
samplers.insert(
|
||||||
);
|
(*wrap_mode, *filter_mode, *mipmap_filter),
|
||||||
samplers.insert(
|
VulkanSampler::new(device, *wrap_mode, *filter_mode, *mipmap_filter)?,
|
||||||
(*wrap_mode, FilterMode::Linear, FilterMode::Nearest),
|
);
|
||||||
VulkanSampler::new(device, *wrap_mode, FilterMode::Linear, FilterMode::Nearest)?,
|
}
|
||||||
);
|
}
|
||||||
|
|
||||||
samplers.insert(
|
|
||||||
(*wrap_mode, FilterMode::Nearest, FilterMode::Nearest),
|
|
||||||
VulkanSampler::new(device, *wrap_mode, FilterMode::Nearest, FilterMode::Nearest)?,
|
|
||||||
);
|
|
||||||
samplers.insert(
|
|
||||||
(*wrap_mode, FilterMode::Nearest, FilterMode::Linear),
|
|
||||||
VulkanSampler::new(device, *wrap_mode, FilterMode::Nearest, FilterMode::Linear)?,
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// assert all samplers were created.
|
||||||
|
assert_eq!(samplers.len(), wrap_modes.len() * 2 * 2);
|
||||||
Ok(SamplerSet { samplers })
|
Ok(SamplerSet { samplers })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,14 +1,9 @@
|
||||||
use ash::vk;
|
use ash::vk;
|
||||||
use gpu_allocator::vulkan::{Allocation, AllocationCreateDesc, AllocationScheme, Allocator};
|
use gpu_allocator::vulkan::{Allocation, AllocationCreateDesc, AllocationScheme, Allocator};
|
||||||
use gpu_allocator::MemoryLocation;
|
use gpu_allocator::MemoryLocation;
|
||||||
use librashader_runtime::uniforms::UniformStorageAccess;
|
|
||||||
use parking_lot::RwLock;
|
use parking_lot::RwLock;
|
||||||
|
|
||||||
use ash::prelude::VkResult;
|
use ash::prelude::VkResult;
|
||||||
use std::ffi::c_void;
|
|
||||||
use std::mem::ManuallyDrop;
|
|
||||||
use std::ops::{Deref, DerefMut};
|
|
||||||
use std::ptr::NonNull;
|
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
pub struct VulkanImageMemory {
|
pub struct VulkanImageMemory {
|
||||||
|
|
|
@ -4,21 +4,6 @@ use gpu_allocator::vulkan::{Allocator, AllocatorCreateDesc};
|
||||||
use parking_lot::RwLock;
|
use parking_lot::RwLock;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
use librashader_reflect::reflect::semantics::BindingStage;
|
|
||||||
|
|
||||||
pub fn binding_stage_to_vulkan_stage(stage_mask: BindingStage) -> vk::ShaderStageFlags {
|
|
||||||
let mut mask = vk::ShaderStageFlags::default();
|
|
||||||
if stage_mask.contains(BindingStage::VERTEX) {
|
|
||||||
mask |= vk::ShaderStageFlags::VERTEX;
|
|
||||||
}
|
|
||||||
|
|
||||||
if stage_mask.contains(BindingStage::FRAGMENT) {
|
|
||||||
mask |= vk::ShaderStageFlags::FRAGMENT;
|
|
||||||
}
|
|
||||||
|
|
||||||
mask
|
|
||||||
}
|
|
||||||
|
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
pub unsafe fn vulkan_image_layout_transition_levels(
|
pub unsafe fn vulkan_image_layout_transition_levels(
|
||||||
device: &ash::Device,
|
device: &ash::Device,
|
||||||
|
|
Loading…
Reference in a new issue