Fix 2 DTK bugs

Bug 1: subcommand 1 of 0xE1 does not actually reset the current position; it just stops playback.  0xE2 returns the same value it would have before stopping playback (other than reporting that the stream is stopped).

Bug 2: subcommand 3 of 0xE2 was incorrectly dividing the length by 4; while this makes sense for positions (which are multiplied by 4 earlier to get a byte offset), it is not correct for lengths.
This commit is contained in:
Pokechu22 2019-09-04 16:02:55 -07:00
parent 828dc0f204
commit 3efa3d7a42

View File

@ -991,11 +991,6 @@ void ExecuteCommand(u32 command_0, u32 command_1, u32 command_2, u32 output_addr
{ {
s_stop_at_track_end = false; s_stop_at_track_end = false;
s_stream = false; s_stream = false;
s_audio_position = 0;
s_next_start = 0;
s_next_length = 0;
s_current_start = 0;
s_current_length = 0;
} }
else else
{ {
@ -1051,7 +1046,7 @@ void ExecuteCommand(u32 command_0, u32 command_1, u32 command_2, u32 output_addr
case 0x03: // Returns the total length case 0x03: // Returns the total length
INFO_LOG(DVDINTERFACE, "(Audio): Stream Status: Request Audio status CurrentLength:%08x", INFO_LOG(DVDINTERFACE, "(Audio): Stream Status: Request Audio status CurrentLength:%08x",
s_current_length); s_current_length);
WriteImmediate(static_cast<u32>(s_current_length >> 2), output_address, reply_to_ios); WriteImmediate(s_current_length, output_address, reply_to_ios);
break; break;
default: default:
INFO_LOG(DVDINTERFACE, "(Audio): Subcommand: %02x Request Audio status %s", INFO_LOG(DVDINTERFACE, "(Audio): Subcommand: %02x Request Audio status %s",