Merge pull request #2659 from MerryMage/dsp_dsp-correction
dsp_dsp: Messages are modified by service before being sent to DSP
This commit is contained in:
commit
6a72bd62b5
|
@ -303,6 +303,24 @@ static void WriteProcessPipe(Service::Interface* self) {
|
||||||
message[i] = Memory::Read8(buffer + i);
|
message[i] = Memory::Read8(buffer + i);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This behaviour was confirmed by RE.
|
||||||
|
// The likely reason for this is that games tend to pass in garbage at these bytes
|
||||||
|
// because they read random bytes off the stack.
|
||||||
|
switch (pipe) {
|
||||||
|
case DSP::HLE::DspPipe::Audio:
|
||||||
|
ASSERT(message.size() >= 4);
|
||||||
|
message[2] = 0;
|
||||||
|
message[3] = 0;
|
||||||
|
break;
|
||||||
|
case DSP::HLE::DspPipe::Binary:
|
||||||
|
ASSERT(message.size() >= 8);
|
||||||
|
message[4] = 1;
|
||||||
|
message[5] = 0;
|
||||||
|
message[6] = 0;
|
||||||
|
message[7] = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
DSP::HLE::PipeWrite(pipe, message);
|
DSP::HLE::PipeWrite(pipe, message);
|
||||||
|
|
||||||
cmd_buff[0] = IPC::MakeHeader(0xD, 1, 0);
|
cmd_buff[0] = IPC::MakeHeader(0xD, 1, 0);
|
||||||
|
|
Loading…
Reference in a new issue