GPU/HW: Fix mask bit regression from FF8 fix

Fixes overbright polygons appearing in Silent Hill.
This commit is contained in:
Stenzek 2024-12-29 14:53:39 +10:00
parent 0e6ade067c
commit 1a211e0a21
No known key found for this signature in database
1 changed files with 8 additions and 4 deletions

View File

@ -2382,6 +2382,8 @@ ALWAYS_INLINE_RELEASE bool GPU_HW::ExpandLineTriangles(BatchVertex* vertices)
// Upload vertices. // Upload vertices.
DebugAssert(m_batch_vertex_space >= 4); DebugAssert(m_batch_vertex_space >= 4);
std::memcpy(m_batch_vertex_ptr, vertices, sizeof(BatchVertex) * 4); std::memcpy(m_batch_vertex_ptr, vertices, sizeof(BatchVertex) * 4);
m_batch_vertex_ptr[0].z = m_batch_vertex_ptr[1].z = m_batch_vertex_ptr[2].z = m_batch_vertex_ptr[3].z =
GetCurrentNormalizedVertexDepth();
m_batch_vertex_ptr += 4; m_batch_vertex_ptr += 4;
m_batch_vertex_count += 4; m_batch_vertex_count += 4;
m_batch_vertex_space -= 4; m_batch_vertex_space -= 4;
@ -2757,7 +2759,6 @@ void GPU_HW::DrawSprite(const GPUBackendDrawRectangleCommand* cmd)
void GPU_HW::DrawPolygon(const GPUBackendDrawPolygonCommand* cmd) void GPU_HW::DrawPolygon(const GPUBackendDrawPolygonCommand* cmd)
{ {
// TODO: This could write directly to the mapped GPU pointer. But watch out for the reads below. // TODO: This could write directly to the mapped GPU pointer. But watch out for the reads below.
const float depth = GetCurrentNormalizedVertexDepth();
const bool raw_texture = (cmd->texture_enable && cmd->raw_texture_enable); const bool raw_texture = (cmd->texture_enable && cmd->raw_texture_enable);
const u32 texpage = ZeroExtend32(cmd->draw_mode.bits) | (ZeroExtend32(cmd->palette.bits) << 16); const u32 texpage = ZeroExtend32(cmd->draw_mode.bits) | (ZeroExtend32(cmd->palette.bits) << 16);
std::array<BatchVertex, 4> vertices; std::array<BatchVertex, 4> vertices;
@ -2766,7 +2767,7 @@ void GPU_HW::DrawPolygon(const GPUBackendDrawPolygonCommand* cmd)
{ {
const GPUBackendDrawPolygonCommand::Vertex& vert = cmd->vertices[i]; const GPUBackendDrawPolygonCommand::Vertex& vert = cmd->vertices[i];
const GSVector2 vert_pos = GSVector2(GSVector2i::load<true>(&vert.x)); const GSVector2 vert_pos = GSVector2(GSVector2i::load<true>(&vert.x));
vertices[i].Set(vert_pos.x, vert_pos.y, depth, 1.0f, raw_texture ? UINT32_C(0x00808080) : vert.color, texpage, vertices[i].Set(vert_pos.x, vert_pos.y, 0.0f, 1.0f, raw_texture ? UINT32_C(0x00808080) : vert.color, texpage,
vert.texcoord, 0xFFFF0000u); vert.texcoord, 0xFFFF0000u);
} }
@ -2791,7 +2792,6 @@ void GPU_HW::DrawPolygon(const GPUBackendDrawPolygonCommand* cmd)
void GPU_HW::DrawPrecisePolygon(const GPUBackendDrawPrecisePolygonCommand* cmd) void GPU_HW::DrawPrecisePolygon(const GPUBackendDrawPrecisePolygonCommand* cmd)
{ {
// TODO: This could write directly to the mapped GPU pointer. But watch out for the reads below. // TODO: This could write directly to the mapped GPU pointer. But watch out for the reads below.
const float depth = GetCurrentNormalizedVertexDepth();
const bool raw_texture = (cmd->texture_enable && cmd->raw_texture_enable); const bool raw_texture = (cmd->texture_enable && cmd->raw_texture_enable);
const u32 texpage = ZeroExtend32(cmd->draw_mode.bits) | (ZeroExtend32(cmd->palette.bits) << 16); const u32 texpage = ZeroExtend32(cmd->draw_mode.bits) | (ZeroExtend32(cmd->palette.bits) << 16);
std::array<BatchVertex, 4> vertices; std::array<BatchVertex, 4> vertices;
@ -2799,7 +2799,7 @@ void GPU_HW::DrawPrecisePolygon(const GPUBackendDrawPrecisePolygonCommand* cmd)
for (u32 i = 0; i < num_vertices; i++) for (u32 i = 0; i < num_vertices; i++)
{ {
const GPUBackendDrawPrecisePolygonCommand::Vertex& vert = cmd->vertices[i]; const GPUBackendDrawPrecisePolygonCommand::Vertex& vert = cmd->vertices[i];
vertices[i].Set(vert.x, vert.y, depth, vert.w, raw_texture ? UINT32_C(0x00808080) : vert.color, texpage, vertices[i].Set(vert.x, vert.y, 0.0f, vert.w, raw_texture ? UINT32_C(0x00808080) : vert.color, texpage,
vert.texcoord, 0xFFFF0000u); vert.texcoord, 0xFFFF0000u);
} }
@ -2991,8 +2991,11 @@ ALWAYS_INLINE_RELEASE void GPU_HW::FinishPolygonDraw(const GPUBackendDrawCommand
m_batch_index_count += 3; m_batch_index_count += 3;
m_batch_index_space -= 3; m_batch_index_space -= 3;
// Fake depth must be written here rather than at vertex init time, because a flush could occur in between.
DebugAssert(m_batch_vertex_space >= 4); DebugAssert(m_batch_vertex_space >= 4);
std::memcpy(m_batch_vertex_ptr, vertices.data(), sizeof(BatchVertex) * 4); std::memcpy(m_batch_vertex_ptr, vertices.data(), sizeof(BatchVertex) * 4);
m_batch_vertex_ptr[0].z = m_batch_vertex_ptr[1].z = m_batch_vertex_ptr[2].z = m_batch_vertex_ptr[3].z =
GetCurrentNormalizedVertexDepth();
m_batch_vertex_ptr += 4; m_batch_vertex_ptr += 4;
m_batch_vertex_count += 4; m_batch_vertex_count += 4;
m_batch_vertex_space -= 4; m_batch_vertex_space -= 4;
@ -3001,6 +3004,7 @@ ALWAYS_INLINE_RELEASE void GPU_HW::FinishPolygonDraw(const GPUBackendDrawCommand
{ {
DebugAssert(m_batch_vertex_space >= 3); DebugAssert(m_batch_vertex_space >= 3);
std::memcpy(m_batch_vertex_ptr, vertices.data(), sizeof(BatchVertex) * 3); std::memcpy(m_batch_vertex_ptr, vertices.data(), sizeof(BatchVertex) * 3);
m_batch_vertex_ptr[0].z = m_batch_vertex_ptr[1].z = m_batch_vertex_ptr[2].z = GetCurrentNormalizedVertexDepth();
m_batch_vertex_ptr += 3; m_batch_vertex_ptr += 3;
m_batch_vertex_count += 3; m_batch_vertex_count += 3;
m_batch_vertex_space -= 3; m_batch_vertex_space -= 3;