[D3D12] Build and code format fixes
This commit is contained in:
parent
87aecfa1b8
commit
c0ff73a588
|
@ -52,11 +52,10 @@ bool D3D12Shader::Prepare() {
|
||||||
// TODO(Triang3l): Choose the appropriate optimization level based on compile
|
// TODO(Triang3l): Choose the appropriate optimization level based on compile
|
||||||
// time and how invariance is handled in vertex shaders.
|
// time and how invariance is handled in vertex shaders.
|
||||||
ID3DBlob* error_blob = nullptr;
|
ID3DBlob* error_blob = nullptr;
|
||||||
bool compiled =
|
bool compiled = SUCCEEDED(
|
||||||
SUCCEEDED(D3DCompile(translated_binary_.data(), translated_binary_.size(),
|
D3DCompile(translated_binary_.data(), translated_binary_.size(), nullptr,
|
||||||
nullptr, nullptr, nullptr, "main", target,
|
nullptr, nullptr, "main", target,
|
||||||
D3DCOMPILE_OPTIMIZATION_LEVEL0, 0, &blob_,
|
D3DCOMPILE_OPTIMIZATION_LEVEL0, 0, &blob_, &error_blob));
|
||||||
&error_blob));
|
|
||||||
|
|
||||||
if (!compiled) {
|
if (!compiled) {
|
||||||
XELOGE("%s shader %.16llX compilation failed!", target, ucode_data_hash());
|
XELOGE("%s shader %.16llX compilation failed!", target, ucode_data_hash());
|
||||||
|
@ -65,14 +64,16 @@ bool D3D12Shader::Prepare() {
|
||||||
if (compiled) {
|
if (compiled) {
|
||||||
XELOGW("%s shader %.16llX compiled with warnings!", target,
|
XELOGW("%s shader %.16llX compiled with warnings!", target,
|
||||||
ucode_data_hash());
|
ucode_data_hash());
|
||||||
XELOGW("%s", reinterpret_cast<const char*>(error_blob->GetBufferPointer()));
|
XELOGW("%s",
|
||||||
|
reinterpret_cast<const char*>(error_blob->GetBufferPointer()));
|
||||||
XELOGW("HLSL source:");
|
XELOGW("HLSL source:");
|
||||||
// The buffer isn't terminated.
|
// The buffer isn't terminated.
|
||||||
translated_binary_.push_back(0);
|
translated_binary_.push_back(0);
|
||||||
XELOGW("%s", reinterpret_cast<const char*>(translated_binary_.data()));
|
XELOGW("%s", reinterpret_cast<const char*>(translated_binary_.data()));
|
||||||
translated_binary_.pop_back();
|
translated_binary_.pop_back();
|
||||||
} else {
|
} else {
|
||||||
XELOGE("%s", reinterpret_cast<const char*>(error_blob->GetBufferPointer()));
|
XELOGE("%s",
|
||||||
|
reinterpret_cast<const char*>(error_blob->GetBufferPointer()));
|
||||||
XELOGE("HLSL source:");
|
XELOGE("HLSL source:");
|
||||||
translated_binary_.push_back(0);
|
translated_binary_.push_back(0);
|
||||||
XELOGE("%s", reinterpret_cast<const char*>(translated_binary_.data()));
|
XELOGE("%s", reinterpret_cast<const char*>(translated_binary_.data()));
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
|
|
||||||
#include "xenia/base/assert.h"
|
#include "xenia/base/assert.h"
|
||||||
#include "xenia/base/logging.h"
|
#include "xenia/base/logging.h"
|
||||||
|
#include "xenia/base/profiling.h"
|
||||||
#include "xenia/gpu/gpu_flags.h"
|
#include "xenia/gpu/gpu_flags.h"
|
||||||
#include "xenia/gpu/hlsl_shader_translator.h"
|
#include "xenia/gpu/hlsl_shader_translator.h"
|
||||||
|
|
||||||
|
@ -28,9 +29,7 @@ PipelineCache::PipelineCache(RegisterFile* register_file,
|
||||||
|
|
||||||
PipelineCache::~PipelineCache() { Shutdown(); }
|
PipelineCache::~PipelineCache() { Shutdown(); }
|
||||||
|
|
||||||
void PipelineCache::Shutdown() {
|
void PipelineCache::Shutdown() { ClearCache(); }
|
||||||
ClearCache();
|
|
||||||
}
|
|
||||||
|
|
||||||
D3D12Shader* PipelineCache::LoadShader(ShaderType shader_type,
|
D3D12Shader* PipelineCache::LoadShader(ShaderType shader_type,
|
||||||
uint32_t guest_address,
|
uint32_t guest_address,
|
||||||
|
@ -47,8 +46,8 @@ D3D12Shader* PipelineCache::LoadShader(ShaderType shader_type,
|
||||||
// Always create the shader and stash it away.
|
// Always create the shader and stash it away.
|
||||||
// We need to track it even if it fails translation so we know not to try
|
// We need to track it even if it fails translation so we know not to try
|
||||||
// again.
|
// again.
|
||||||
D3D12Shader* shader = new D3D12Shader(shader_type, data_hash, host_address,
|
D3D12Shader* shader =
|
||||||
dword_count);
|
new D3D12Shader(shader_type, data_hash, host_address, dword_count);
|
||||||
shader_map_.insert({data_hash, shader});
|
shader_map_.insert({data_hash, shader});
|
||||||
|
|
||||||
return shader;
|
return shader;
|
||||||
|
|
|
@ -13,9 +13,9 @@
|
||||||
// This must be included before D3D and DXGI for things like NOMINMAX.
|
// This must be included before D3D and DXGI for things like NOMINMAX.
|
||||||
#include "xenia/base/platform_win.h"
|
#include "xenia/base/platform_win.h"
|
||||||
|
|
||||||
#include <dxgi1_4.h>
|
|
||||||
#include <d3d12.h>
|
#include <d3d12.h>
|
||||||
#include <d3dcompiler.h>
|
#include <d3dcompiler.h>
|
||||||
|
#include <dxgi1_4.h>
|
||||||
|
|
||||||
#define XELOGD3D XELOGI
|
#define XELOGD3D XELOGI
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue