From f79e16eb4dccee4b34df719171f17dc6feaaf1d6 Mon Sep 17 00:00:00 2001 From: DH Date: Wed, 23 Oct 2024 02:32:43 +0300 Subject: [PATCH] gpu: workaround write to context register with SET_CONFIG_REG --- rpcsx/gpu/Pipe.cpp | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/rpcsx/gpu/Pipe.cpp b/rpcsx/gpu/Pipe.cpp index 45ad54c..1e08cb2 100644 --- a/rpcsx/gpu/Pipe.cpp +++ b/rpcsx/gpu/Pipe.cpp @@ -1423,6 +1423,19 @@ bool GraphicsPipe::setConfigReg(Ring &ring) { auto offset = ring.rptr[1] & 0xffff; auto data = ring.rptr + 2; + auto mmioOffset = decltype(device->config)::kMmioOffset + offset; + + // FIXME: verify + if (mmioOffset >= decltype(context)::kMmioOffset) { + auto contextOffset = mmioOffset - decltype(context)::kMmioOffset; + + if (contextOffset + len <= sizeof(context)) { + std::memcpy(reinterpret_cast(&context) + contextOffset, + data, sizeof(std::uint32_t) * len); + return true; + } + } + rx::dieIf( (offset + len) * sizeof(std::uint32_t) > sizeof(device->config), "out of Config regs, offset: %x, count %u, %s\n", offset, len,