mirror of
https://github.com/doitsujin/dxvk.git
synced 2025-03-15 07:29:17 +01:00
130 lines
3.4 KiB
C++
130 lines
3.4 KiB
C++
#include "dxvk_device.h"
|
|
#include "dxvk_pipemanager.h"
|
|
#include "dxvk_state_cache.h"
|
|
|
|
namespace dxvk {
|
|
|
|
size_t DxvkPipelineKeyHash::operator () (const DxvkComputePipelineShaders& key) const {
|
|
std::hash<DxvkShader*> hash;
|
|
return hash(key.cs.ptr());
|
|
}
|
|
|
|
|
|
size_t DxvkPipelineKeyHash::operator () (const DxvkGraphicsPipelineShaders& key) const {
|
|
DxvkHashState state;
|
|
|
|
std::hash<DxvkShader*> hash;
|
|
state.add(hash(key.vs.ptr()));
|
|
state.add(hash(key.tcs.ptr()));
|
|
state.add(hash(key.tes.ptr()));
|
|
state.add(hash(key.gs.ptr()));
|
|
state.add(hash(key.fs.ptr()));
|
|
return state;
|
|
}
|
|
|
|
|
|
bool DxvkPipelineKeyEq::operator () (
|
|
const DxvkComputePipelineShaders& a,
|
|
const DxvkComputePipelineShaders& b) const {
|
|
return a.cs == b.cs;
|
|
}
|
|
|
|
|
|
bool DxvkPipelineKeyEq::operator () (
|
|
const DxvkGraphicsPipelineShaders& a,
|
|
const DxvkGraphicsPipelineShaders& b) const {
|
|
return a.vs == b.vs && a.tcs == b.tcs
|
|
&& a.tes == b.tes && a.gs == b.gs
|
|
&& a.fs == b.fs;
|
|
}
|
|
|
|
|
|
DxvkPipelineManager::DxvkPipelineManager(
|
|
const DxvkDevice* device,
|
|
DxvkRenderPassPool* passManager)
|
|
: m_device (device),
|
|
m_cache (new DxvkPipelineCache(device->vkd())) {
|
|
std::string useStateCache = env::getEnvVar("DXVK_STATE_CACHE");
|
|
|
|
if (useStateCache != "0" && device->config().enableStateCache)
|
|
m_stateCache = new DxvkStateCache(device, this, passManager);
|
|
}
|
|
|
|
|
|
DxvkPipelineManager::~DxvkPipelineManager() {
|
|
|
|
}
|
|
|
|
|
|
Rc<DxvkComputePipeline> DxvkPipelineManager::createComputePipeline(
|
|
const Rc<DxvkShader>& cs) {
|
|
if (cs == nullptr)
|
|
return nullptr;
|
|
|
|
std::lock_guard<std::mutex> lock(m_mutex);
|
|
|
|
DxvkComputePipelineShaders key;
|
|
key.cs = cs;
|
|
|
|
auto pair = m_computePipelines.find(key);
|
|
if (pair != m_computePipelines.end())
|
|
return pair->second;
|
|
|
|
Rc<DxvkComputePipeline> pipeline = new DxvkComputePipeline(this, key);
|
|
|
|
m_computePipelines.insert(std::make_pair(key, pipeline));
|
|
return pipeline;
|
|
}
|
|
|
|
|
|
Rc<DxvkGraphicsPipeline> DxvkPipelineManager::createGraphicsPipeline(
|
|
const Rc<DxvkShader>& vs,
|
|
const Rc<DxvkShader>& tcs,
|
|
const Rc<DxvkShader>& tes,
|
|
const Rc<DxvkShader>& gs,
|
|
const Rc<DxvkShader>& fs) {
|
|
if (vs == nullptr)
|
|
return nullptr;
|
|
|
|
std::lock_guard<std::mutex> lock(m_mutex);
|
|
|
|
DxvkGraphicsPipelineShaders key;
|
|
key.vs = vs;
|
|
key.tcs = tcs;
|
|
key.tes = tes;
|
|
key.gs = gs;
|
|
key.fs = fs;
|
|
|
|
auto pair = m_graphicsPipelines.find(key);
|
|
if (pair != m_graphicsPipelines.end())
|
|
return pair->second;
|
|
|
|
Rc<DxvkGraphicsPipeline> pipeline = new DxvkGraphicsPipeline(this, key);
|
|
|
|
m_graphicsPipelines.insert(std::make_pair(key, pipeline));
|
|
return pipeline;
|
|
}
|
|
|
|
|
|
void DxvkPipelineManager::registerShader(
|
|
const Rc<DxvkShader>& shader) {
|
|
if (m_stateCache != nullptr)
|
|
m_stateCache->registerShader(shader);
|
|
}
|
|
|
|
|
|
DxvkPipelineCount DxvkPipelineManager::getPipelineCount() const {
|
|
DxvkPipelineCount result;
|
|
result.numComputePipelines = m_numComputePipelines.load();
|
|
result.numGraphicsPipelines = m_numGraphicsPipelines.load();
|
|
return result;
|
|
}
|
|
|
|
|
|
bool DxvkPipelineManager::isCompilingShaders() const {
|
|
return m_stateCache != nullptr
|
|
&& m_stateCache->isCompilingShaders();
|
|
}
|
|
|
|
}
|