mirror of
https://github.com/wheremyfoodat/Panda3DS.git
synced 2025-06-08 12:01:39 +12:00
fix: hashes
This commit is contained in:
parent
a783f09e7c
commit
d8937e5827
6 changed files with 63 additions and 25 deletions
|
@ -1,5 +1,7 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
|
||||||
#include "pica_to_mtl.hpp"
|
#include "pica_to_mtl.hpp"
|
||||||
|
|
||||||
using namespace PICA;
|
using namespace PICA;
|
||||||
|
@ -63,7 +65,7 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::unordered_map<u8, MTL::RenderPipelineState*> pipelineCache;
|
std::map<u8, MTL::RenderPipelineState*> pipelineCache;
|
||||||
|
|
||||||
MTL::Device* device;
|
MTL::Device* device;
|
||||||
MTL::Function* vertexFunction;
|
MTL::Function* vertexFunction;
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
|
||||||
#include "pica_to_mtl.hpp"
|
#include "pica_to_mtl.hpp"
|
||||||
|
|
||||||
using namespace PICA;
|
using namespace PICA;
|
||||||
|
@ -76,7 +78,7 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::unordered_map<u64, MTL::DepthStencilState*> depthStencilCache;
|
std::map<u64, MTL::DepthStencilState*> depthStencilCache;
|
||||||
|
|
||||||
MTL::Device* device;
|
MTL::Device* device;
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,11 +1,35 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
|
||||||
#include "pica_to_mtl.hpp"
|
#include "pica_to_mtl.hpp"
|
||||||
|
|
||||||
using namespace PICA;
|
using namespace PICA;
|
||||||
|
|
||||||
namespace Metal {
|
namespace Metal {
|
||||||
|
|
||||||
|
struct DrawFragmentFunctionHash {
|
||||||
|
bool lightingEnabled; // 1 bit
|
||||||
|
u8 lightingNumLights; // 3 bits
|
||||||
|
u32 lightingConfig1; // 32 bits (TODO: check this)
|
||||||
|
// | ref | func | on |
|
||||||
|
u16 alphaControl; // 12 bits (mask: 11111111 0111 0001)
|
||||||
|
};
|
||||||
|
|
||||||
|
//bool operator==(const DrawFragmentFunctionHash& l, const DrawFragmentFunctionHash& r) {
|
||||||
|
// return ((l.lightingEnabled == r.lightingEnabled) && (l.lightingNumLights == r.lightingNumLights) &&
|
||||||
|
// (l.lightingConfig1 == r.lightingConfig1) && (l.alphaControl == r.alphaControl));
|
||||||
|
//}
|
||||||
|
|
||||||
|
inline bool operator<(const DrawFragmentFunctionHash& l, const DrawFragmentFunctionHash& r) {
|
||||||
|
if (!l.lightingEnabled && r.lightingEnabled) return true;
|
||||||
|
if (l.lightingNumLights < r.lightingNumLights) return true;
|
||||||
|
if (l.lightingConfig1 < r.lightingConfig1) return true;
|
||||||
|
if (l.alphaControl < r.alphaControl) return true;
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
struct DrawPipelineHash { // 56 bits
|
struct DrawPipelineHash { // 56 bits
|
||||||
// Formats
|
// Formats
|
||||||
ColorFmt colorFmt; // 3 bits
|
ColorFmt colorFmt; // 3 bits
|
||||||
|
@ -17,14 +41,26 @@ struct DrawPipelineHash { // 56 bits
|
||||||
u32 blendControl; // 22 bits (mask: 1111111111111111 00000111 00000111)
|
u32 blendControl; // 22 bits (mask: 1111111111111111 00000111 00000111)
|
||||||
u8 colorWriteMask; // 4 bits
|
u8 colorWriteMask; // 4 bits
|
||||||
|
|
||||||
// Specialization constants (23 bits)
|
DrawFragmentFunctionHash fragHash;
|
||||||
bool lightingEnabled; // 1 bit
|
|
||||||
u8 lightingNumLights; // 3 bits
|
|
||||||
u8 lightingConfig1; // 7 bits
|
|
||||||
// | ref | func | on |
|
|
||||||
u16 alphaControl; // 12 bits (mask: 11111111 0111 0001)
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//bool operator==(const DrawPipelineHash& l, const DrawPipelineHash& r) {
|
||||||
|
// return (((u32)l.colorFmt == (u32)r.colorFmt) && ((u32)l.depthFmt == (u32)r.depthFmt) &&
|
||||||
|
// (l.blendEnabled == r.blendEnabled) && (l.blendControl == r.blendControl) &&
|
||||||
|
// (l.colorWriteMask == r.colorWriteMask) && (l.fragHash == r.fragHash));
|
||||||
|
//}
|
||||||
|
|
||||||
|
inline bool operator<(const DrawPipelineHash& l, const DrawPipelineHash& r) {
|
||||||
|
if ((u32)l.colorFmt < (u32)r.colorFmt) return true;
|
||||||
|
if ((u32)l.depthFmt < (u32)r.depthFmt) return true;
|
||||||
|
if (!l.blendEnabled && r.blendEnabled) return true;
|
||||||
|
if (l.blendControl < r.blendControl) return true;
|
||||||
|
if (l.colorWriteMask < r.colorWriteMask) return true;
|
||||||
|
if (l.fragHash < r.fragHash) return true;
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Bind the vertex buffer to binding 30 so that it doesn't occupy the lower indices
|
// Bind the vertex buffer to binding 30 so that it doesn't occupy the lower indices
|
||||||
#define VERTEX_BUFFER_BINDING_INDEX 30
|
#define VERTEX_BUFFER_BINDING_INDEX 30
|
||||||
|
|
||||||
|
@ -47,17 +83,17 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
MTL::RenderPipelineState* get(DrawPipelineHash hash) {
|
MTL::RenderPipelineState* get(DrawPipelineHash hash) {
|
||||||
u32 fragmentFunctionHash = ((u32)hash.lightingEnabled << 22) | ((u32)hash.lightingNumLights << 19) | ((u32)hash.lightingConfig1 << 12) | ((((u32)hash.alphaControl & 0b1111111100000000) >> 8) << 4) | ((((u32)hash.alphaControl & 0b01110000) >> 4) << 1) | ((u32)hash.alphaControl & 0b0001);
|
//u32 fragmentFunctionHash = ((u32)hash.lightingEnabled << 22) | ((u32)hash.lightingNumLights << 19) | ((u32)hash.lightingConfig1 << 12) | ((((u32)hash.alphaControl & 0b1111111100000000) >> 8) << 4) | ((((u32)hash.alphaControl & 0b01110000) >> 4) << 1) | ((u32)hash.alphaControl & 0b0001);
|
||||||
u64 pipelineHash = ((u64)hash.colorFmt << 53) | ((u64)hash.depthFmt << 50) | ((u64)hash.blendEnabled << 49) | ((u64)hash.colorWriteMask << 45) | ((((u64)hash.blendControl & 0b11111111111111110000000000000000) >> 16) << 29) | ((((u64)hash.blendControl & 0b0000011100000000) >> 8) << 26) | (((u64)hash.blendControl & 0b00000111) << 23) | fragmentFunctionHash;
|
//u64 pipelineHash = ((u64)hash.colorFmt << 53) | ((u64)hash.depthFmt << 50) | ((u64)hash.blendEnabled << 49) | ((u64)hash.colorWriteMask << 45) | ((((u64)hash.blendControl & 0b11111111111111110000000000000000) >> 16) << 29) | ((((u64)hash.blendControl & 0b0000011100000000) >> 8) << 26) | (((u64)hash.blendControl & 0b00000111) << 23) | fragmentFunctionHash;
|
||||||
auto& pipeline = pipelineCache[pipelineHash];
|
auto& pipeline = pipelineCache[hash];
|
||||||
if (!pipeline) {
|
if (!pipeline) {
|
||||||
auto& fragmentFunction = fragmentFunctionCache[fragmentFunctionHash];
|
auto& fragmentFunction = fragmentFunctionCache[hash.fragHash];
|
||||||
if (!fragmentFunction) {
|
if (!fragmentFunction) {
|
||||||
MTL::FunctionConstantValues* constants = MTL::FunctionConstantValues::alloc()->init();
|
MTL::FunctionConstantValues* constants = MTL::FunctionConstantValues::alloc()->init();
|
||||||
constants->setConstantValue(&hash.lightingEnabled, MTL::DataTypeBool, NS::UInteger(0));
|
constants->setConstantValue(&hash.fragHash.lightingEnabled, MTL::DataTypeBool, NS::UInteger(0));
|
||||||
constants->setConstantValue(&hash.lightingNumLights, MTL::DataTypeUChar, NS::UInteger(1));
|
constants->setConstantValue(&hash.fragHash.lightingNumLights, MTL::DataTypeUChar, NS::UInteger(1));
|
||||||
constants->setConstantValue(&hash.lightingConfig1, MTL::DataTypeUChar, NS::UInteger(2));
|
constants->setConstantValue(&hash.fragHash.lightingConfig1, MTL::DataTypeUInt, NS::UInteger(2));
|
||||||
constants->setConstantValue(&hash.alphaControl, MTL::DataTypeUShort, NS::UInteger(3));
|
constants->setConstantValue(&hash.fragHash.alphaControl, MTL::DataTypeUShort, NS::UInteger(3));
|
||||||
|
|
||||||
NS::Error* error = nullptr;
|
NS::Error* error = nullptr;
|
||||||
fragmentFunction = library->newFunction(NS::String::string("fragmentDraw", NS::ASCIIStringEncoding), constants, &error);
|
fragmentFunction = library->newFunction(NS::String::string("fragmentDraw", NS::ASCIIStringEncoding), constants, &error);
|
||||||
|
@ -65,7 +101,6 @@ public:
|
||||||
Helpers::panic("Error creating draw fragment function: %s", error->description()->cString(NS::ASCIIStringEncoding));
|
Helpers::panic("Error creating draw fragment function: %s", error->description()->cString(NS::ASCIIStringEncoding));
|
||||||
}
|
}
|
||||||
constants->release();
|
constants->release();
|
||||||
fragmentFunctionCache[fragmentFunctionHash] = fragmentFunction;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MTL::RenderPipelineDescriptor* desc = MTL::RenderPipelineDescriptor::alloc()->init();
|
MTL::RenderPipelineDescriptor* desc = MTL::RenderPipelineDescriptor::alloc()->init();
|
||||||
|
@ -127,8 +162,8 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::unordered_map<u64, MTL::RenderPipelineState*> pipelineCache;
|
std::map<DrawPipelineHash, MTL::RenderPipelineState*> pipelineCache;
|
||||||
std::unordered_map<u32, MTL::Function*> fragmentFunctionCache;
|
std::map<DrawFragmentFunctionHash, MTL::Function*> fragmentFunctionCache;
|
||||||
|
|
||||||
MTL::Device* device;
|
MTL::Device* device;
|
||||||
MTL::Library* library;
|
MTL::Library* library;
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <map>
|
|
||||||
#include "pica_to_mtl.hpp"
|
#include "pica_to_mtl.hpp"
|
||||||
|
|
||||||
using namespace PICA;
|
using namespace PICA;
|
||||||
|
|
|
@ -476,10 +476,10 @@ void RendererMTL::drawVertices(PICA::PrimType primType, std::span<const PICA::Ve
|
||||||
if (depthStencilRenderTarget) {
|
if (depthStencilRenderTarget) {
|
||||||
pipelineHash.depthFmt = depthStencilRenderTarget->format;
|
pipelineHash.depthFmt = depthStencilRenderTarget->format;
|
||||||
}
|
}
|
||||||
pipelineHash.lightingEnabled = regs[0x008F] & 1;
|
pipelineHash.fragHash.lightingEnabled = regs[0x008F] & 1;
|
||||||
pipelineHash.lightingNumLights = regs[0x01C2] & 0x7;
|
pipelineHash.fragHash.lightingNumLights = regs[0x01C2] & 0x7;
|
||||||
pipelineHash.lightingConfig1 = regs[0x01C4u] >> 16; // Last 16 bits are unused, so skip them
|
pipelineHash.fragHash.lightingConfig1 = regs[0x01C4u];
|
||||||
pipelineHash.alphaControl = regs[0x104];
|
pipelineHash.fragHash.alphaControl = regs[0x104];
|
||||||
|
|
||||||
// Blending and logic op
|
// Blending and logic op
|
||||||
pipelineHash.blendEnabled = (regs[PICA::InternalRegs::ColourOperation] & (1 << 8)) != 0;
|
pipelineHash.blendEnabled = (regs[PICA::InternalRegs::ColourOperation] & (1 << 8)) != 0;
|
||||||
|
|
|
@ -223,7 +223,7 @@ vertex DrawVertexOutWithClip vertexDraw(DrawVertexIn in [[stage_in]], constant P
|
||||||
|
|
||||||
constant bool lightingEnabled [[function_constant(0)]];
|
constant bool lightingEnabled [[function_constant(0)]];
|
||||||
constant uint8_t lightingNumLights [[function_constant(1)]];
|
constant uint8_t lightingNumLights [[function_constant(1)]];
|
||||||
constant uint8_t lightingConfig1 [[function_constant(2)]];
|
constant uint32_t lightingConfig1 [[function_constant(2)]];
|
||||||
constant uint16_t alphaControl [[function_constant(3)]];
|
constant uint16_t alphaControl [[function_constant(3)]];
|
||||||
|
|
||||||
struct Globals {
|
struct Globals {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue