mirror of
https://github.com/skyline-emu/skyline.git
synced 2025-01-28 15:27:54 +03:00
Implement Maxwell3D Independent/Common Color Blending
Maxwell3D supports independent blending which has different blending per-RT and common blending which has the same blending for all RTs. There is a register determining which mode to utilize and we simply have two arrays of `VkPipelineColorBlendAttachmentState` for the RTs that we toggle between to make the transition between them extremely cheap.
This commit is contained in:
parent
2ceb6465e8
commit
92809f8a78
@ -482,7 +482,11 @@ namespace skyline::gpu::interconnect {
|
|||||||
|
|
||||||
/* Color Blending */
|
/* Color Blending */
|
||||||
private:
|
private:
|
||||||
vk::PipelineColorBlendStateCreateInfo blendState{};
|
std::array<vk::PipelineColorBlendAttachmentState, maxwell3d::RenderTargetCount> commonRtBlendState{}, independentRtBlendState{}; //!< Per-RT blending state for common/independent blending for trivial toggling behavior
|
||||||
|
vk::PipelineColorBlendStateCreateInfo blendState{
|
||||||
|
.pAttachments = commonRtBlendState.data(),
|
||||||
|
.attachmentCount = maxwell3d::RenderTargetCount,
|
||||||
|
};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void SetBlendLogicOpEnable(bool enabled) {
|
void SetBlendLogicOpEnable(bool enabled) {
|
||||||
@ -532,9 +536,193 @@ namespace skyline::gpu::interconnect {
|
|||||||
}();
|
}();
|
||||||
}
|
}
|
||||||
|
|
||||||
void SetAlphaTestEnable(bool enable) {
|
void SetAlphaTestEnabled(bool enable) {
|
||||||
if (enable)
|
if (enable)
|
||||||
Logger::Warn("Cannot enable alpha testing due to Vulkan constraints");
|
Logger::Warn("Cannot enable alpha testing due to Vulkan constraints");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
vk::BlendOp ConvertBlendOp(maxwell3d::BlendOp op) {
|
||||||
|
switch (op) {
|
||||||
|
case maxwell3d::BlendOp::Add:
|
||||||
|
case maxwell3d::BlendOp::AddGL:
|
||||||
|
return vk::BlendOp::eAdd;
|
||||||
|
|
||||||
|
case maxwell3d::BlendOp::Subtract:
|
||||||
|
case maxwell3d::BlendOp::SubtractGL:
|
||||||
|
return vk::BlendOp::eSubtract;
|
||||||
|
|
||||||
|
case maxwell3d::BlendOp::ReverseSubtract:
|
||||||
|
case maxwell3d::BlendOp::ReverseSubtractGL:
|
||||||
|
return vk::BlendOp::eReverseSubtract;
|
||||||
|
|
||||||
|
case maxwell3d::BlendOp::Minimum:
|
||||||
|
case maxwell3d::BlendOp::MinimumGL:
|
||||||
|
return vk::BlendOp::eMin;
|
||||||
|
|
||||||
|
case maxwell3d::BlendOp::Maximum:
|
||||||
|
case maxwell3d::BlendOp::MaximumGL:
|
||||||
|
return vk::BlendOp::eMax;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
vk::BlendFactor ConvertBlendFactor(maxwell3d::BlendFactor factor) {
|
||||||
|
switch (factor) {
|
||||||
|
case maxwell3d::BlendFactor::Zero:
|
||||||
|
case maxwell3d::BlendFactor::ZeroGL:
|
||||||
|
return vk::BlendFactor::eZero;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::One:
|
||||||
|
case maxwell3d::BlendFactor::OneGL:
|
||||||
|
return vk::BlendFactor::eOne;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::SourceColor:
|
||||||
|
case maxwell3d::BlendFactor::SourceColorGL:
|
||||||
|
return vk::BlendFactor::eSrcColor;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::OneMinusSourceColor:
|
||||||
|
case maxwell3d::BlendFactor::OneMinusSourceColorGL:
|
||||||
|
return vk::BlendFactor::eOneMinusSrcColor;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::SourceAlpha:
|
||||||
|
case maxwell3d::BlendFactor::SourceAlphaGL:
|
||||||
|
return vk::BlendFactor::eSrcAlpha;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::OneMinusSourceAlpha:
|
||||||
|
case maxwell3d::BlendFactor::OneMinusSourceAlphaGL:
|
||||||
|
return vk::BlendFactor::eOneMinusSrcColor;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::DestAlpha:
|
||||||
|
case maxwell3d::BlendFactor::DestAlphaGL:
|
||||||
|
return vk::BlendFactor::eDstAlpha;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::OneMinusDestAlpha:
|
||||||
|
case maxwell3d::BlendFactor::OneMinusDestAlphaGL:
|
||||||
|
return vk::BlendFactor::eOneMinusDstAlpha;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::DestColor:
|
||||||
|
case maxwell3d::BlendFactor::DestColorGL:
|
||||||
|
return vk::BlendFactor::eDstColor;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::OneMinusDestColor:
|
||||||
|
case maxwell3d::BlendFactor::OneMinusDestColorGL:
|
||||||
|
return vk::BlendFactor::eOneMinusDstColor;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::SourceAlphaSaturate:
|
||||||
|
case maxwell3d::BlendFactor::SourceAlphaSaturateGL:
|
||||||
|
return vk::BlendFactor::eSrcAlphaSaturate;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::Source1Color:
|
||||||
|
case maxwell3d::BlendFactor::Source1ColorGL:
|
||||||
|
return vk::BlendFactor::eSrc1Color;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::OneMinusSource1Color:
|
||||||
|
case maxwell3d::BlendFactor::OneMinusSource1ColorGL:
|
||||||
|
return vk::BlendFactor::eOneMinusSrc1Color;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::Source1Alpha:
|
||||||
|
case maxwell3d::BlendFactor::Source1AlphaGL:
|
||||||
|
return vk::BlendFactor::eSrc1Alpha;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::OneMinusSource1Alpha:
|
||||||
|
case maxwell3d::BlendFactor::OneMinusSource1AlphaGL:
|
||||||
|
return vk::BlendFactor::eOneMinusSrc1Alpha;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::ConstantColor:
|
||||||
|
case maxwell3d::BlendFactor::ConstantColorGL:
|
||||||
|
return vk::BlendFactor::eConstantColor;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::OneMinusConstantColor:
|
||||||
|
case maxwell3d::BlendFactor::OneMinusConstantColorGL:
|
||||||
|
return vk::BlendFactor::eOneMinusConstantColor;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::ConstantAlpha:
|
||||||
|
case maxwell3d::BlendFactor::ConstantAlphaGL:
|
||||||
|
return vk::BlendFactor::eConstantAlpha;
|
||||||
|
|
||||||
|
case maxwell3d::BlendFactor::OneMinusConstantAlpha:
|
||||||
|
case maxwell3d::BlendFactor::OneMinusConstantAlphaGL:
|
||||||
|
return vk::BlendFactor::eOneMinusConstantAlpha;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetIndependentBlendingEnabled(bool enable) {
|
||||||
|
if (enable)
|
||||||
|
blendState.pAttachments = independentRtBlendState.data();
|
||||||
|
else
|
||||||
|
blendState.pAttachments = commonRtBlendState.data();
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetColorBlendEnabled(bool enable) {
|
||||||
|
for (auto &blend : commonRtBlendState)
|
||||||
|
blend.blendEnable = enable;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetColorBlendOp(maxwell3d::BlendOp op) {
|
||||||
|
auto vkOp{ConvertBlendOp(op)};
|
||||||
|
for (auto &blend : commonRtBlendState)
|
||||||
|
blend.colorBlendOp = vkOp;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetSrcColorBlendFactor(maxwell3d::BlendFactor factor) {
|
||||||
|
auto vkFactor{ConvertBlendFactor(factor)};
|
||||||
|
for (auto &blend : commonRtBlendState)
|
||||||
|
blend.srcColorBlendFactor = vkFactor;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetDstColorBlendFactor(maxwell3d::BlendFactor factor) {
|
||||||
|
auto vkFactor{ConvertBlendFactor(factor)};
|
||||||
|
for (auto &blend : commonRtBlendState)
|
||||||
|
blend.dstColorBlendFactor = vkFactor;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetAlphaBlendOp(maxwell3d::BlendOp op) {
|
||||||
|
auto vkOp{ConvertBlendOp(op)};
|
||||||
|
for (auto &blend : commonRtBlendState)
|
||||||
|
blend.alphaBlendOp = vkOp;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetSrcAlphaBlendFactor(maxwell3d::BlendFactor factor) {
|
||||||
|
auto vkFactor{ConvertBlendFactor(factor)};
|
||||||
|
for (auto &blend : commonRtBlendState)
|
||||||
|
blend.srcAlphaBlendFactor = vkFactor;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetDstAlphaBlendFactor(maxwell3d::BlendFactor factor) {
|
||||||
|
auto vkFactor{ConvertBlendFactor(factor)};
|
||||||
|
for (auto &blend : commonRtBlendState)
|
||||||
|
blend.dstAlphaBlendFactor = vkFactor;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetColorBlendEnabled(u32 index, bool enable) {
|
||||||
|
independentRtBlendState[index].blendEnable = enable;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetColorBlendOp(u32 index, maxwell3d::BlendOp op) {
|
||||||
|
independentRtBlendState[index].colorBlendOp = ConvertBlendOp(op);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetSrcColorBlendFactor(u32 index, maxwell3d::BlendFactor factor) {
|
||||||
|
independentRtBlendState[index].srcColorBlendFactor = ConvertBlendFactor(factor);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetDstColorBlendFactor(u32 index, maxwell3d::BlendFactor factor) {
|
||||||
|
independentRtBlendState[index].dstColorBlendFactor = ConvertBlendFactor(factor);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetAlphaBlendOp(u32 index, maxwell3d::BlendOp op) {
|
||||||
|
independentRtBlendState[index].alphaBlendOp = ConvertBlendOp(op);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetSrcAlphaBlendFactor(u32 index, maxwell3d::BlendFactor factor) {
|
||||||
|
independentRtBlendState[index].srcAlphaBlendFactor = ConvertBlendFactor(factor);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetDstAlphaBlendFactor(u32 index, maxwell3d::BlendFactor factor) {
|
||||||
|
independentRtBlendState[index].dstAlphaBlendFactor = ConvertBlendFactor(factor);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetColorBlendConstant(u32 index, float constant) {
|
||||||
|
blendState.blendConstants[index] = constant;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -302,75 +302,63 @@ namespace skyline::soc::gm20b::engine::maxwell3d::type {
|
|||||||
AlwaysGL = 0x207,
|
AlwaysGL = 0x207,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Blend {
|
constexpr static size_t BlendColorChannelCount{4}; //!< The amount of color channels in operations such as blending
|
||||||
enum class Op : u32 {
|
|
||||||
Add = 1,
|
|
||||||
Subtract = 2,
|
|
||||||
ReverseSubtract = 3,
|
|
||||||
Minimum = 4,
|
|
||||||
Maximum = 5,
|
|
||||||
|
|
||||||
AddGL = 0x8006,
|
enum class BlendOp : u32 {
|
||||||
SubtractGL = 0x8007,
|
Add = 1,
|
||||||
ReverseSubtractGL = 0x8008,
|
Subtract = 2,
|
||||||
MinimumGL = 0x800A,
|
ReverseSubtract = 3,
|
||||||
MaximumGL = 0x800B,
|
Minimum = 4,
|
||||||
};
|
Maximum = 5,
|
||||||
|
|
||||||
enum class Factor : u32 {
|
AddGL = 0x8006,
|
||||||
Zero = 0x1,
|
SubtractGL = 0x8007,
|
||||||
One = 0x2,
|
ReverseSubtractGL = 0x8008,
|
||||||
SourceColor = 0x3,
|
MinimumGL = 0x800A,
|
||||||
OneMinusSourceColor = 0x4,
|
MaximumGL = 0x800B,
|
||||||
SourceAlpha = 0x5,
|
};
|
||||||
OneMinusSourceAlpha = 0x6,
|
|
||||||
DestAlpha = 0x7,
|
enum class BlendFactor : u32 {
|
||||||
OneMinusDestAlpha = 0x8,
|
Zero = 0x1,
|
||||||
DestColor = 0x9,
|
One = 0x2,
|
||||||
OneMinusDestColor = 0xA,
|
SourceColor = 0x3,
|
||||||
SourceAlphaSaturate = 0xB,
|
OneMinusSourceColor = 0x4,
|
||||||
Source1Color = 0x10,
|
SourceAlpha = 0x5,
|
||||||
OneMinusSource1Color = 0x11,
|
OneMinusSourceAlpha = 0x6,
|
||||||
Source1Alpha = 0x12,
|
DestAlpha = 0x7,
|
||||||
OneMinusSource1Alpha = 0x13,
|
OneMinusDestAlpha = 0x8,
|
||||||
ConstantColor = 0x61,
|
DestColor = 0x9,
|
||||||
OneMinusConstantColor = 0x62,
|
OneMinusDestColor = 0xA,
|
||||||
ConstantAlpha = 0x63,
|
SourceAlphaSaturate = 0xB,
|
||||||
OneMinusConstantAlpha = 0x64,
|
Source1Color = 0x10,
|
||||||
|
OneMinusSource1Color = 0x11,
|
||||||
ZeroGL = 0x4000,
|
Source1Alpha = 0x12,
|
||||||
OneGL = 0x4001,
|
OneMinusSource1Alpha = 0x13,
|
||||||
SourceColorGL = 0x4300,
|
ConstantColor = 0x61,
|
||||||
OneMinusSourceColorGL = 0x4301,
|
OneMinusConstantColor = 0x62,
|
||||||
SourceAlphaGL = 0x4302,
|
ConstantAlpha = 0x63,
|
||||||
OneMinusSourceAlphaGL = 0x4303,
|
OneMinusConstantAlpha = 0x64,
|
||||||
DestAlphaGL = 0x4304,
|
|
||||||
OneMinusDestAlphaGL = 0x4305,
|
ZeroGL = 0x4000,
|
||||||
DestColorGL = 0x4306,
|
OneGL = 0x4001,
|
||||||
OneMinusDestColorGL = 0x4307,
|
SourceColorGL = 0x4300,
|
||||||
SourceAlphaSaturateGL = 0x4308,
|
OneMinusSourceColorGL = 0x4301,
|
||||||
ConstantColorGL = 0xC001,
|
SourceAlphaGL = 0x4302,
|
||||||
OneMinusConstantColorGL = 0xC002,
|
OneMinusSourceAlphaGL = 0x4303,
|
||||||
ConstantAlphaGL = 0xC003,
|
DestAlphaGL = 0x4304,
|
||||||
OneMinusConstantAlphaGL = 0xC004,
|
OneMinusDestAlphaGL = 0x4305,
|
||||||
Source1ColorGL = 0xC900,
|
DestColorGL = 0x4306,
|
||||||
OneMinusSource1ColorGL = 0xC901,
|
OneMinusDestColorGL = 0x4307,
|
||||||
Source1AlphaGL = 0xC902,
|
SourceAlphaSaturateGL = 0x4308,
|
||||||
OneMinusSource1AlphaGL = 0xC903,
|
ConstantColorGL = 0xC001,
|
||||||
};
|
OneMinusConstantColorGL = 0xC002,
|
||||||
|
ConstantAlphaGL = 0xC003,
|
||||||
struct {
|
OneMinusConstantAlphaGL = 0xC004,
|
||||||
u32 seperateAlpha;
|
Source1ColorGL = 0xC900,
|
||||||
Op colorOp;
|
OneMinusSource1ColorGL = 0xC901,
|
||||||
Factor colorSrcFactor;
|
Source1AlphaGL = 0xC902,
|
||||||
Factor colorDestFactor;
|
OneMinusSource1AlphaGL = 0xC903,
|
||||||
Op alphaOp;
|
|
||||||
Factor alphaSrcFactor;
|
|
||||||
Factor alphaDestFactor;
|
|
||||||
u32 _pad_;
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
static_assert(sizeof(Blend) == (sizeof(u32) * 8));
|
|
||||||
|
|
||||||
struct MultisampleControl {
|
struct MultisampleControl {
|
||||||
bool alphaToCoverage : 1;
|
bool alphaToCoverage : 1;
|
||||||
|
@ -183,10 +183,60 @@ namespace skyline::soc::gm20b::engine::maxwell3d {
|
|||||||
context.UpdateRenderTargetControl(renderTargetControl);
|
context.UpdateRenderTargetControl(renderTargetControl);
|
||||||
})
|
})
|
||||||
|
|
||||||
MAXWELL3D_CASE(alphaTestEnable, {
|
MAXWELL3D_CASE(independentBlendEnable, {
|
||||||
context.SetAlphaTestEnable(alphaTestEnable);
|
context.SetIndependentBlendingEnabled(independentBlendEnable);
|
||||||
})
|
})
|
||||||
|
|
||||||
|
MAXWELL3D_CASE(alphaTestEnable, {
|
||||||
|
context.SetAlphaTestEnabled(alphaTestEnable);
|
||||||
|
})
|
||||||
|
|
||||||
|
#define SET_COLOR_BLEND_CONSTANT_CALLBACK(z, index, data) \
|
||||||
|
MAXWELL3D_ARRAY_CASE(blendConstant, index, { \
|
||||||
|
context.SetColorBlendConstant(index, blendConstant); \
|
||||||
|
})
|
||||||
|
|
||||||
|
BOOST_PP_REPEAT(4, SET_COLOR_BLEND_CONSTANT_CALLBACK, 0)
|
||||||
|
static_assert(type::BlendColorChannelCount == 4 && type::BlendColorChannelCount < BOOST_PP_LIMIT_REPEAT);
|
||||||
|
#undef SET_COLOR_BLEND_CONSTANT_CALLBACK
|
||||||
|
|
||||||
|
MAXWELL3D_STRUCT_CASE(blendStateCommon, colorOp, {
|
||||||
|
context.SetColorBlendOp(colorOp);
|
||||||
|
})
|
||||||
|
|
||||||
|
MAXWELL3D_STRUCT_CASE(blendStateCommon, colorSrcFactor, {
|
||||||
|
context.SetSrcColorBlendFactor(colorSrcFactor);
|
||||||
|
})
|
||||||
|
|
||||||
|
MAXWELL3D_STRUCT_CASE(blendStateCommon, colorDstFactor, {
|
||||||
|
context.SetDstColorBlendFactor(colorDstFactor);
|
||||||
|
})
|
||||||
|
|
||||||
|
MAXWELL3D_STRUCT_CASE(blendStateCommon, alphaOp, {
|
||||||
|
context.SetAlphaBlendOp(alphaOp);
|
||||||
|
})
|
||||||
|
|
||||||
|
MAXWELL3D_STRUCT_CASE(blendStateCommon, alphaSrcFactor, {
|
||||||
|
context.SetSrcAlphaBlendFactor(alphaSrcFactor);
|
||||||
|
})
|
||||||
|
|
||||||
|
MAXWELL3D_STRUCT_CASE(blendStateCommon, alphaDstFactor, {
|
||||||
|
context.SetDstAlphaBlendFactor(alphaDstFactor);
|
||||||
|
})
|
||||||
|
|
||||||
|
MAXWELL3D_STRUCT_CASE(blendStateCommon, enable, {
|
||||||
|
context.SetColorBlendEnabled(enable);
|
||||||
|
})
|
||||||
|
|
||||||
|
#define SET_COLOR_BLEND_ENABLE_CALLBACK(z, index, data) \
|
||||||
|
MAXWELL3D_ARRAY_CASE(rtBlendEnable, index, { \
|
||||||
|
context.SetColorBlendEnabled(index, rtBlendEnable); \
|
||||||
|
})
|
||||||
|
|
||||||
|
BOOST_PP_REPEAT(8, SET_COLOR_BLEND_ENABLE_CALLBACK, 0)
|
||||||
|
static_assert(type::RenderTargetCount == 8 && type::RenderTargetCount < BOOST_PP_LIMIT_REPEAT);
|
||||||
|
#undef SET_COLOR_BLEND_ENABLE_CALLBACK
|
||||||
|
|
||||||
MAXWELL3D_CASE(lineWidthSmooth, {
|
MAXWELL3D_CASE(lineWidthSmooth, {
|
||||||
if (*registers.lineSmoothEnable)
|
if (*registers.lineSmoothEnable)
|
||||||
context.SetLineWidth(lineWidthSmooth);
|
context.SetLineWidth(lineWidthSmooth);
|
||||||
@ -249,6 +299,30 @@ namespace skyline::soc::gm20b::engine::maxwell3d {
|
|||||||
context.SetBlendLogicOpType(type);
|
context.SetBlendLogicOpType(type);
|
||||||
})
|
})
|
||||||
|
|
||||||
|
#define SET_INDEPENDENT_COLOR_BLEND_CALLBACKS(z, index, data) \
|
||||||
|
MAXWELL3D_ARRAY_STRUCT_CASE(independentBlend, index, colorOp, { \
|
||||||
|
context.SetColorBlendOp(index, colorOp); \
|
||||||
|
}) \
|
||||||
|
MAXWELL3D_ARRAY_STRUCT_CASE(independentBlend, index, colorSrcFactor, { \
|
||||||
|
context.SetSrcColorBlendFactor(index, colorSrcFactor); \
|
||||||
|
}) \
|
||||||
|
MAXWELL3D_ARRAY_STRUCT_CASE(independentBlend, index, colorDstFactor, { \
|
||||||
|
context.SetDstColorBlendFactor(index, colorDstFactor); \
|
||||||
|
}) \
|
||||||
|
MAXWELL3D_ARRAY_STRUCT_CASE(independentBlend, index, alphaOp, { \
|
||||||
|
context.SetAlphaBlendOp(index, alphaOp); \
|
||||||
|
}) \
|
||||||
|
MAXWELL3D_ARRAY_STRUCT_CASE(independentBlend, index, alphaSrcFactor, { \
|
||||||
|
context.SetSrcAlphaBlendFactor(index, alphaSrcFactor); \
|
||||||
|
}) \
|
||||||
|
MAXWELL3D_ARRAY_STRUCT_CASE(independentBlend, index, alphaDstFactor, { \
|
||||||
|
context.SetDstAlphaBlendFactor(index, alphaDstFactor); \
|
||||||
|
})
|
||||||
|
|
||||||
|
BOOST_PP_REPEAT(8, SET_INDEPENDENT_COLOR_BLEND_CALLBACKS, 0)
|
||||||
|
static_assert(type::RenderTargetCount == 8 && type::RenderTargetCount < BOOST_PP_LIMIT_REPEAT);
|
||||||
|
#undef SET_COLOR_BLEND_ENABLE_CALLBACK
|
||||||
|
|
||||||
#define SET_SHADER_ENABLE_CALLBACK(z, index, data) \
|
#define SET_SHADER_ENABLE_CALLBACK(z, index, data) \
|
||||||
MAXWELL3D_ARRAY_STRUCT_CASE(setProgram, index, info, { \
|
MAXWELL3D_ARRAY_STRUCT_CASE(setProgram, index, info, { \
|
||||||
context.SetShaderEnabled(info.stage, info.enable); \
|
context.SetShaderEnabled(info.stage, info.enable); \
|
||||||
|
@ -45,7 +45,6 @@ namespace skyline::soc::gm20b::engine::maxwell3d {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @url https://github.com/devkitPro/deko3d/blob/master/source/maxwell/engine_3d.def
|
* @url https://github.com/devkitPro/deko3d/blob/master/source/maxwell/engine_3d.def
|
||||||
* @note To ease the extension of this structure, padding may follow both _padN_ and _padN_M_ formats
|
|
||||||
*/
|
*/
|
||||||
#pragma pack(push, 1)
|
#pragma pack(push, 1)
|
||||||
union Registers {
|
union Registers {
|
||||||
@ -108,6 +107,7 @@ namespace skyline::soc::gm20b::engine::maxwell3d {
|
|||||||
Register<0x3EB, u32> rtSeparateFragData;
|
Register<0x3EB, u32> rtSeparateFragData;
|
||||||
Register<0x458, std::array<type::VertexAttribute, 0x20>> vertexAttributeState;
|
Register<0x458, std::array<type::VertexAttribute, 0x20>> vertexAttributeState;
|
||||||
Register<0x487, type::RenderTargetControl> renderTargetControl;
|
Register<0x487, type::RenderTargetControl> renderTargetControl;
|
||||||
|
Register<0x4B9, u32> independentBlendEnable;
|
||||||
Register<0x4BB, u32> alphaTestEnable;
|
Register<0x4BB, u32> alphaTestEnable;
|
||||||
Register<0x4C3, type::CompareOp> depthTestFunc;
|
Register<0x4C3, type::CompareOp> depthTestFunc;
|
||||||
Register<0x4C4, float> alphaTestRef;
|
Register<0x4C4, float> alphaTestRef;
|
||||||
@ -115,26 +115,28 @@ namespace skyline::soc::gm20b::engine::maxwell3d {
|
|||||||
Register<0x4C6, u32> drawTFBStride;
|
Register<0x4C6, u32> drawTFBStride;
|
||||||
|
|
||||||
struct BlendConstant {
|
struct BlendConstant {
|
||||||
float r; // 0x4C7
|
float red; // 0x4C7
|
||||||
float g; // 0x4C8
|
float green; // 0x4C8
|
||||||
float b; // 0x4C9
|
float blue; // 0x4C9
|
||||||
float a; // 0x4CA
|
float alpha; // 0x4CA
|
||||||
};
|
};
|
||||||
Register<0x4C7, BlendConstant> blendConstant;
|
Register<0x4C7, std::array<float, type::BlendColorChannelCount>> blendConstant;
|
||||||
|
|
||||||
struct BlendState {
|
struct BlendStateCommon {
|
||||||
u32 seperateAlpha; // 0x4CF
|
u32 seperateAlpha; // 0x4CF
|
||||||
type::Blend::Op colorOp; // 0x4D0
|
type::BlendOp colorOp; // 0x4D0
|
||||||
type::Blend::Factor colorSrcFactor; // 0x4D1
|
type::BlendFactor colorSrcFactor; // 0x4D1
|
||||||
type::Blend::Factor colorDestFactor; // 0x4D2
|
type::BlendFactor colorDstFactor; // 0x4D2
|
||||||
type::Blend::Op alphaOp; // 0x4D3
|
type::BlendOp alphaOp; // 0x4D3
|
||||||
type::Blend::Factor alphaSrcFactor; // 0x4D4
|
type::BlendFactor alphaSrcFactor; // 0x4D4
|
||||||
type::Blend::Factor alphaDestFactor; // 0x4D6
|
u32 pad; // 0x4D5
|
||||||
|
type::BlendFactor alphaDstFactor; // 0x4D6
|
||||||
|
|
||||||
u32 enableCommon; // 0x4D7
|
u32 enable; // 0x4D7
|
||||||
std::array<u32, 8> enable; // 0x4D8 For each render target
|
|
||||||
};
|
};
|
||||||
Register<0x4CF, BlendState> blendState;
|
Register<0x4CF, BlendStateCommon> blendStateCommon;
|
||||||
|
|
||||||
|
Register<0x4D8, std::array<u32, type::RenderTargetCount>> rtBlendEnable;
|
||||||
|
|
||||||
Register<0x4E0, u32> stencilEnable;
|
Register<0x4E0, u32> stencilEnable;
|
||||||
struct StencilFront {
|
struct StencilFront {
|
||||||
@ -226,7 +228,17 @@ namespace skyline::soc::gm20b::engine::maxwell3d {
|
|||||||
};
|
};
|
||||||
Register<0x671, ColorLogicOp> colorLogicOp;
|
Register<0x671, ColorLogicOp> colorLogicOp;
|
||||||
|
|
||||||
Register<0x780, std::array<type::Blend, type::RenderTargetCount>> independentBlend;
|
struct IndependentBlend {
|
||||||
|
u32 seperateAlpha;
|
||||||
|
type::BlendOp colorOp;
|
||||||
|
type::BlendFactor colorSrcFactor;
|
||||||
|
type::BlendFactor colorDstFactor;
|
||||||
|
type::BlendOp alphaOp;
|
||||||
|
type::BlendFactor alphaSrcFactor;
|
||||||
|
type::BlendFactor alphaDstFactor;
|
||||||
|
u32 _pad_;
|
||||||
|
};
|
||||||
|
Register<0x780, std::array<IndependentBlend, type::RenderTargetCount>> independentBlend;
|
||||||
|
|
||||||
Register<0x800, std::array<type::SetProgramInfo, type::StageCount>> setProgram;
|
Register<0x800, std::array<type::SetProgramInfo, type::StageCount>> setProgram;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user