Skip to content

Commit

Permalink
rsx: Properly fill in the cyclic ref field for framebuffer references
Browse files Browse the repository at this point in the history
  • Loading branch information
kd-11 committed Jul 1, 2023
1 parent 459c04c commit ad04ccf
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 5 deletions.
8 changes: 5 additions & 3 deletions rpcs3/Emu/RSX/Common/texture_cache.h
Original file line number Diff line number Diff line change
Expand Up @@ -262,6 +262,8 @@ namespace rsx
if (sections.size() == 1 && section_fills_target(sections[0]))
{
const auto cpy = sections[0];
external_subresource_desc.external_ref_addr = cpy.base_addr;

if (section_is_transfer_only(cpy))
{
// Change the command to copy_image_static
Expand All @@ -275,7 +277,6 @@ namespace rsx
// Blit op is a semantic variant of the copy and atlas ops.
// We can simply reuse the atlas handler for this for now, but this allows simplification.
external_subresource_desc.op = deferred_request_command::blit_image_static;
external_subresource_desc.external_ref_addr = cpy.base_addr;
}
}
}
Expand Down Expand Up @@ -1997,17 +1998,18 @@ namespace rsx
position2i(result.external_subresource_desc.x, result.external_subresource_desc.y),
size2i(result.external_subresource_desc.width, result.external_subresource_desc.height),
size2i(result.external_subresource_desc.external_handle->width(), result.external_subresource_desc.external_handle->height()),
encoded_remap, remap, false /* FIXME */);
encoded_remap, remap, false);
}
else
{
helpers::convert_image_blit_to_clip_descriptor(
result,
encoded_remap,
remap,
false /* FIXME */);
false);
}

result.is_cyclic_reference = !!result.ref_address && m_rtts.address_is_bound(result.ref_address);
return result;
}

Expand Down
4 changes: 2 additions & 2 deletions rpcs3/Emu/RSX/Common/texture_cache_helpers.h
Original file line number Diff line number Diff line change
Expand Up @@ -318,7 +318,7 @@ namespace rsx
({
.src = section.surface->get_surface(rsx::surface_access::transfer_read),
.xform = surface_transform::identity,
.base_addr = section.base_addr,
.base_addr = section.base_address,
.level = 0,
.src_x = static_cast<u16>(src_x),
.src_y = static_cast<u16>(src_y),
Expand Down Expand Up @@ -384,7 +384,6 @@ namespace rsx
({
.src = section->get_raw_texture(),
.xform = surface_transform::identity,
.base_addr = address,
.level = 0,
.src_x = static_cast<u16>(src_offset.x), // src.x
.src_y = static_cast<u16>(src_offset.y), // src.y
Expand Down Expand Up @@ -542,6 +541,7 @@ namespace rsx
bool cyclic_reference)
{
desc.image_handle = desc.external_subresource_desc.as_viewable()->get_view(encoded_remap, decoded_remap);
desc.ref_address = desc.external_subresource_desc.external_ref_addr;
desc.is_cyclic_reference = cyclic_reference;
desc.samples = desc.external_subresource_desc.external_handle->samples();
desc.external_subresource_desc = {};
Expand Down

0 comments on commit ad04ccf

Please sign in to comment.