[Kernel] Fix StoreXmaContextIndexedRegister, note about physical addresses in XMAInitializeContext
This commit is contained in:
parent
b01f6cd7ea
commit
9df39e4883
|
@ -80,8 +80,12 @@ DECLARE_XBOXKRNL_EXPORT2(XMAReleaseContext, kAudio, kImplemented,
|
|||
|
||||
void StoreXmaContextIndexedRegister(KernelState* kernel_state,
|
||||
uint32_t base_reg, uint32_t context_ptr) {
|
||||
uint32_t context_physical_address =
|
||||
kernel_memory()->GetPhysicalAddress(context_ptr);
|
||||
assert_true(context_physical_address != UINT32_MAX);
|
||||
auto xma_decoder = kernel_state->emulator()->audio_system()->xma_decoder();
|
||||
uint32_t hw_index = (context_ptr - xma_decoder->context_array_ptr()) /
|
||||
uint32_t hw_index =
|
||||
(context_physical_address - xma_decoder->context_array_ptr()) /
|
||||
sizeof(XMA_CONTEXT_DATA);
|
||||
uint32_t reg_num = base_reg + (hw_index >> 5) * 4;
|
||||
uint32_t reg_value = 1 << (hw_index & 0x1F);
|
||||
|
@ -119,6 +123,9 @@ dword_result_t XMAInitializeContext(lpvoid_t context_ptr,
|
|||
|
||||
XMA_CONTEXT_DATA context(context_ptr);
|
||||
|
||||
// input_buffer_0_ptr, input_buffer_1_ptr and output_buffer_ptr are physical
|
||||
// already and good enough for us, checked in sk8er boi simulators skate. and
|
||||
// Tony Hawk's American Wasteland. Can be 0 also (in THAW).
|
||||
context.input_buffer_0_ptr = context_init->input_buffer_0_ptr;
|
||||
context.input_buffer_0_packet_count =
|
||||
context_init->input_buffer_0_packet_count;
|
||||
|
|
Loading…
Reference in New Issue