Added SHVkSampler and SHVKSamplerCache
This commit is contained in:
parent
a6f7ffab43
commit
5e7ffd6028
|
@ -16,6 +16,7 @@
|
|||
#include "Graphics/Framebuffer/SHVkFramebuffer.h"
|
||||
#include "Graphics/Images/SHVkImageView.h"
|
||||
#include "Graphics/Descriptors/SHVkDescriptorSetGroup.h"
|
||||
#include "Graphics/Images/SHVkSampler.h"
|
||||
|
||||
namespace SHADE
|
||||
{
|
||||
|
@ -85,6 +86,17 @@ namespace SHADE
|
|||
|
||||
}
|
||||
|
||||
uint32_t SHVkLogicalDevice::ComputeAlignedBufferSize(uint32_t originalSize, size_t alignmentSize) const noexcept
|
||||
{
|
||||
uint32_t alignedSize = originalSize;
|
||||
//uint32_t minBuffer
|
||||
if (alignmentSize > 0)
|
||||
{
|
||||
alignedSize = (alignedSize + alignmentSize - 1) & ~(alignmentSize - 1);
|
||||
}
|
||||
return alignedSize;
|
||||
}
|
||||
|
||||
/***************************************************************************/
|
||||
/*!
|
||||
|
||||
|
@ -288,13 +300,12 @@ namespace SHADE
|
|||
|
||||
uint32_t SHVkLogicalDevice::PadUBOSize(uint32_t originalSize) const noexcept
|
||||
{
|
||||
uint32_t alignedSize = originalSize;
|
||||
//uint32_t minBuffer
|
||||
if (uboBufferMemoryAlignment > 0)
|
||||
{
|
||||
alignedSize = (alignedSize + uboBufferMemoryAlignment - 1) & ~(uboBufferMemoryAlignment - 1);
|
||||
}
|
||||
return alignedSize;
|
||||
return ComputeAlignedBufferSize(originalSize, uboBufferMemoryAlignment);
|
||||
}
|
||||
|
||||
uint32_t SHVkLogicalDevice::PadSSBOSize(uint32_t originalSize) const noexcept
|
||||
{
|
||||
return ComputeAlignedBufferSize(originalSize, ssboBufferMemoryAlignment);
|
||||
}
|
||||
|
||||
/***************************************************************************/
|
||||
|
@ -499,6 +510,11 @@ namespace SHADE
|
|||
|
||||
}
|
||||
|
||||
Handle<SHVkSampler> SHVkLogicalDevice::CreateSampler(const SHVkSamplerParams& params) noexcept
|
||||
{
|
||||
return SHVkInstance::GetResourceManager().Create <SHVkSampler>(GetHandle(), params);
|
||||
}
|
||||
|
||||
Handle<SHVkRenderpass> SHVkLogicalDevice::CreateRenderpass(std::span<vk::AttachmentDescription> const vkDescriptions, std::vector<SHVkSubpassParams> const& subpasses) noexcept
|
||||
{
|
||||
return SHVkInstance::GetResourceManager().Create <SHVkRenderpass>(GetHandle(), vkDescriptions, subpasses);
|
||||
|
|
|
@ -102,6 +102,7 @@ namespace SHADE
|
|||
/*-----------------------------------------------------------------------*/
|
||||
void InitializeVMA (void) noexcept;
|
||||
void InitializeQueues (std::initializer_list<SHQueueParams> queueCreateParams) noexcept;
|
||||
uint32_t ComputeAlignedBufferSize(uint32_t originalSize, size_t typeSize) const noexcept;
|
||||
|
||||
public:
|
||||
/*-----------------------------------------------------------------------*/
|
||||
|
@ -121,7 +122,8 @@ namespace SHADE
|
|||
// Miscellaneous functions
|
||||
void WaitIdle (void) noexcept;
|
||||
uint32_t FindMemoryType (uint32_t typeFilter, vk::MemoryPropertyFlags properties);
|
||||
uint32_t PadUBOSize (uint32_t originalSize) const noexcept;
|
||||
uint32_t PadUBOSize(uint32_t originalSize) const noexcept;
|
||||
uint32_t PadSSBOSize(uint32_t originalSize) const noexcept;
|
||||
|
||||
// creation functions
|
||||
Handle<SHVkSurface> CreateSurface (HWND const& windowHandle) const noexcept;
|
||||
|
@ -178,6 +180,7 @@ namespace SHADE
|
|||
Handle<SHVkRenderpass> const& renderpassHdl,
|
||||
Handle<SHSubpass> subpass
|
||||
) noexcept;
|
||||
Handle<SHVkSampler> CreateSampler (const SHVkSamplerParams& params) noexcept;
|
||||
|
||||
Handle<SHVkRenderpass> CreateRenderpass (std::span<vk::AttachmentDescription> const vkDescriptions, std::vector<SHVkSubpassParams> const& subpasses) noexcept;
|
||||
Handle<SHVkRenderpass> CreateRenderpass (std::span<vk::AttachmentDescription> const vkDescriptions, std::span<vk::SubpassDescription> const spDescs, std::span<vk::SubpassDependency> const spDeps) noexcept;
|
||||
|
|
|
@ -1,12 +1,61 @@
|
|||
/************************************************************************************//*!
|
||||
\file SHVkSampler.cpp
|
||||
\author Tng Kah Wei, kahwei.tng, 390009620
|
||||
\par email: kahwei.tng\@digipen.edu
|
||||
\date Sep 26, 2022
|
||||
\brief Contains definitions for all of the functions of the SHVkSampler class.
|
||||
|
||||
Copyright (C) 2022 DigiPen Institute of Technology.
|
||||
Reproduction or disclosure of this file or its contents without the prior written consent
|
||||
of DigiPen Institute of Technology is prohibited.
|
||||
*//*************************************************************************************/
|
||||
#include "SHpch.h"
|
||||
#include "SHVkSampler.h"
|
||||
|
||||
#include "Graphics/Devices/SHVkLogicalDevice.h"
|
||||
|
||||
namespace SHADE
|
||||
{
|
||||
|
||||
vk::Sampler SHVkSampler::GetVkSampler(void) const noexcept
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
/* Constructors */
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
SHVkSampler::SHVkSampler(Handle<SHVkLogicalDevice> logicalDevice, const SHVkSamplerParams& params) noexcept
|
||||
: device { logicalDevice }
|
||||
{
|
||||
return vkSampler;
|
||||
const vk::SamplerCreateInfo SAMPLER_CREATE_INFO
|
||||
{
|
||||
.magFilter = params.magFilter,
|
||||
.minFilter = params.minFilter,
|
||||
.mipmapMode = params.mipmapMode,
|
||||
.addressModeU = params.addressMode,
|
||||
.addressModeV = params.addressMode,
|
||||
.addressModeW = params.addressMode,
|
||||
.minLod = params.minLod,
|
||||
.maxLod = params.maxLod
|
||||
};
|
||||
|
||||
// Create the sampler
|
||||
vkSampler = device->GetVkLogicalDevice().createSampler(SAMPLER_CREATE_INFO);
|
||||
}
|
||||
|
||||
SHVkSampler::SHVkSampler(SHVkSampler&& rhs) noexcept
|
||||
: vkSampler { rhs.vkSampler }
|
||||
{
|
||||
rhs.vkSampler = nullptr;
|
||||
}
|
||||
|
||||
SHVkSampler::~SHVkSampler() noexcept
|
||||
{
|
||||
if (vkSampler)
|
||||
device->GetVkLogicalDevice().destroySampler();
|
||||
}
|
||||
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
/* Overloaded Operators */
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
SHADE::SHVkSampler&& SHVkSampler::operator=(SHVkSampler&& rhs) noexcept
|
||||
{
|
||||
vkSampler = rhs.vkSampler;
|
||||
rhs.vkSampler = nullptr;
|
||||
}
|
||||
}
|
|
@ -1,28 +1,80 @@
|
|||
/************************************************************************************//*!
|
||||
\file SHVkSampler.h
|
||||
\author Tng Kah Wei, kahwei.tng, 390009620
|
||||
\par email: kahwei.tng\@digipen.edu
|
||||
\date Sep 26, 2022
|
||||
\brief Contains definitions of the SHVkSampler class.
|
||||
|
||||
Copyright (C) 2022 DigiPen Institute of Technology.
|
||||
Reproduction or disclosure of this file or its contents without the prior written consent
|
||||
of DigiPen Institute of Technology is prohibited.
|
||||
*//*************************************************************************************/
|
||||
#pragma once
|
||||
|
||||
// STL Includes
|
||||
#include <vector>
|
||||
// Project Includes
|
||||
#include "Graphics/SHVulkanIncludes.h"
|
||||
#include "Resource/Handle.h"
|
||||
|
||||
namespace SHADE
|
||||
{
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
/* Forward Declarations */
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
class SHVkLogicalDevice;
|
||||
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
/* Type Definitions */
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
/*************************************************************************************/
|
||||
/*!
|
||||
\brief
|
||||
Holds parameters for constructing the SHVkSampler.
|
||||
*/
|
||||
/*************************************************************************************/
|
||||
struct SHVkSamplerParams
|
||||
{
|
||||
vk::Filter minFilter;
|
||||
vk::Filter maxFilter;
|
||||
//vk::Filter maxFilter;
|
||||
vk::Filter minFilter = vk::Filter::eLinear;
|
||||
vk::Filter magFilter = vk::Filter::eLinear;
|
||||
vk::SamplerAddressMode addressMode = vk::SamplerAddressMode::eClampToEdge;
|
||||
vk::SamplerMipmapMode mipmapMode = vk::SamplerMipmapMode::eLinear;
|
||||
float minLod = 0;
|
||||
float maxLod = 0;
|
||||
};
|
||||
|
||||
|
||||
/*************************************************************************************/
|
||||
/*!
|
||||
\brief
|
||||
Wrapper for a VkSampler.
|
||||
*/
|
||||
/*************************************************************************************/
|
||||
class SHVkSampler
|
||||
{
|
||||
private:
|
||||
//! The vulkan sampler handler
|
||||
vk::Sampler vkSampler;
|
||||
|
||||
public:
|
||||
SHVkSampler () noexcept;
|
||||
SHVkSampler (SHVkSampler&& rhs) noexcept;
|
||||
public:
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Constructors */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
SHVkSampler(Handle<SHVkLogicalDevice> logicalDevice, const SHVkSamplerParams& params = {}) noexcept;
|
||||
SHVkSampler(SHVkSampler&& rhs) noexcept;
|
||||
~SHVkSampler() noexcept;
|
||||
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Overloaded Operators */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
SHVkSampler&& operator=(SHVkSampler&& rhs) noexcept;
|
||||
|
||||
vk::Sampler GetVkSampler (void) const noexcept;
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Getter Functions */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
vk::Sampler GetVkSampler(void) const noexcept { return vkSampler; }
|
||||
|
||||
private:
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Data Members */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
vk::Sampler vkSampler; //! The Vulkan sampler handler
|
||||
Handle<SHVkLogicalDevice> device; //! Stored device for deallocating the object
|
||||
};
|
||||
}
|
||||
|
||||
|
|
|
@ -0,0 +1,81 @@
|
|||
/************************************************************************************//*!
|
||||
\file SHVkSamplerCache.cpp
|
||||
\author Tng Kah Wei, kahwei.tng, 390009620
|
||||
\par email: kahwei.tng\@digipen.edu
|
||||
\date Mar 16, 2022
|
||||
\brief Contains the implementation for the SHVkSamplerCache class.
|
||||
|
||||
Copyright (C) 2022 DigiPen Institute of Technology.
|
||||
Reproduction or disclosure of this file or its contents without the prior written consent
|
||||
of DigiPen Institute of Technology is prohibited.
|
||||
*//*************************************************************************************/
|
||||
#include "SHVkSamplerCache.h"
|
||||
|
||||
// Standard Library
|
||||
#include <functional>
|
||||
// Project Header
|
||||
#include "Graphics/Images/SHVkSampler.h"
|
||||
#include "Graphics/Devices/SHVkLogicalDevice.h"
|
||||
|
||||
namespace SHADE
|
||||
{
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Constructors/Destructors */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
SHSamplerCache::SHSamplerCache(Handle<SHVkLogicalDevice> logicalDevice) noexcept
|
||||
: device { logicalDevice }
|
||||
{}
|
||||
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Utility Functions */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
void SHSamplerCache::Clear()
|
||||
{
|
||||
samplersMap.clear();
|
||||
}
|
||||
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Getter Functions */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
Handle<SHVkSampler> SHSamplerCache::GetSampler(const SHVkSamplerParams& params)
|
||||
{
|
||||
// Get the hash to check if it was cached
|
||||
const RawSamplerHash HASH = calcHash
|
||||
(
|
||||
params.minFilter,
|
||||
params.magFilter,
|
||||
params.addressMode,
|
||||
params.mipmapMode,
|
||||
params.minLod,
|
||||
params.maxLod
|
||||
);
|
||||
|
||||
// Check if it was cached
|
||||
auto sampler = samplersMap.find(HASH);
|
||||
if (sampler == samplersMap.end())
|
||||
{
|
||||
const auto BUILD_RESULT = samplersMap.emplace(HASH, device->CreateSampler(params));
|
||||
sampler = BUILD_RESULT.first;
|
||||
}
|
||||
|
||||
return sampler->second;
|
||||
}
|
||||
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Helper Functions */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
SHSamplerCache::RawSamplerHash SHSamplerCache::calcHash(vk::Filter minFilter, vk::Filter magFilter, vk::SamplerAddressMode addressMode, vk::SamplerMipmapMode mipmapMode, float minLod, float maxLod)
|
||||
{
|
||||
static auto charHasher = std::hash<uint8_t>{};
|
||||
static auto floatHasher = std::hash<float>{};
|
||||
|
||||
const RawSamplerHash H1 = charHasher(static_cast<uint8_t>(minFilter));
|
||||
const RawSamplerHash H2 = charHasher(static_cast<uint8_t>(magFilter));
|
||||
const RawSamplerHash H3 = charHasher(static_cast<uint8_t>(addressMode));
|
||||
const RawSamplerHash H4 = charHasher(static_cast<uint8_t>(mipmapMode));
|
||||
const RawSamplerHash H5 = floatHasher(minLod);
|
||||
const RawSamplerHash H6 = floatHasher(maxLod);
|
||||
|
||||
return H1 ^ (H2 << 1) ^ (H3 << 2) ^ (H4 << 3) ^ (H5 << 4) ^ (H6 << 5);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,91 @@
|
|||
/************************************************************************************//*!
|
||||
\file SHSamplerCache.h
|
||||
\author Tng Kah Wei, kahwei.tng, 390009620
|
||||
\par email: kahwei.tng\@digipen.edu
|
||||
\date Mar 16, 2022
|
||||
\brief Contains the interface for the SHSamplerCache class.
|
||||
|
||||
Copyright (C) 2022 DigiPen Institute of Technology.
|
||||
Reproduction or disclosure of this file or its contents without the prior written consent
|
||||
of DigiPen Institute of Technology is prohibited.
|
||||
*//*************************************************************************************/
|
||||
#pragma once
|
||||
|
||||
// Standard Libraries
|
||||
#include <unordered_map>
|
||||
// External Dependencies
|
||||
#include "Graphics/SHVulkanIncludes.h"
|
||||
// Project Includes
|
||||
#include "Resource/Handle.h"
|
||||
|
||||
namespace SHADE
|
||||
{
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
/* Forward Declarations */
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
class SHVkLogicalDevice;
|
||||
class SHVkSampler;
|
||||
struct SHVkSamplerParams;
|
||||
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
/* Type Definitions */
|
||||
/*-----------------------------------------------------------------------------------*/
|
||||
/*************************************************************************************/
|
||||
/*!
|
||||
\brief
|
||||
Class that is responsible for caching and providing Samplers to the user for
|
||||
sampling textures.
|
||||
*/
|
||||
/*************************************************************************************/
|
||||
class SHSamplerCache
|
||||
{
|
||||
public:
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Constructors/Destructors */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
explicit SHSamplerCache(Handle<SHVkLogicalDevice> logicalDevice) noexcept;
|
||||
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Utility Functions */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/// <summary>
|
||||
/// Clears the cache, destroying all created samplers.
|
||||
/// </summary>
|
||||
void Clear();
|
||||
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Getter Functions */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/// <summary>
|
||||
/// Retrieves a Vulkan Sampler of the specified type. If this was retrieved
|
||||
/// before, a cached copy of the Vulkan Sampler will be provided.
|
||||
/// </summary>
|
||||
/// <param name="filterMode">Filtering mode of the Sampler to retrieve.</param>
|
||||
/// <param name="addressMode">Addressing mode of the Sampler to retrieve.</param>
|
||||
/// <param name="mipmapMode">Mipmap mode to use.</param>
|
||||
/// <param name="minLod">Minimum LOD. Usually 0.0f.</param>
|
||||
/// <param name="maxLod">
|
||||
/// Maximum LOD. Usually the mipmap level of the texture.
|
||||
/// </param>
|
||||
/// <returns>Handle to the Vulkan Sampler object specified.</returns>
|
||||
Handle<SHVkSampler> GetSampler(const SHVkSamplerParams& params);
|
||||
|
||||
private:
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Type Definitions */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
using RawSamplerHash = size_t;
|
||||
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Data Members */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
// Resources
|
||||
Handle<SHVkLogicalDevice> device;
|
||||
std::unordered_map<RawSamplerHash, Handle<SHVkSampler>> samplersMap;
|
||||
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
/* Helper Functions */
|
||||
/*---------------------------------------------------------------------------------*/
|
||||
static RawSamplerHash calcHash(vk::Filter minFilter, vk::Filter magFilter, vk::SamplerAddressMode addressMode, vk::SamplerMipmapMode mipmapMode, float minLod, float maxLod);
|
||||
};
|
||||
}
|
Loading…
Reference in New Issue