DMA: Channels other than OTC should run based on request in SyncMode 0

This commit is contained in:
Connor McLaughlin 2020-03-21 00:15:49 +10:00
parent f4d172df2f
commit 8ef1e71ce0

View file

@ -147,6 +147,11 @@ void DMA::WriteRegister(u32 offset, u32 value)
state.channel_control.bits = (state.channel_control.bits & ~ChannelState::ChannelControl::WRITE_MASK) | state.channel_control.bits = (state.channel_control.bits & ~ChannelState::ChannelControl::WRITE_MASK) |
(value & ChannelState::ChannelControl::WRITE_MASK); (value & ChannelState::ChannelControl::WRITE_MASK);
Log_TracePrintf("DMA channel %u channel control <- 0x%08X", channel_index, state.channel_control.bits); Log_TracePrintf("DMA channel %u channel control <- 0x%08X", channel_index, state.channel_control.bits);
// start/trigger bit must be enabled for OTC
if (static_cast<Channel>(channel_index) == Channel::OTC)
SetRequest(static_cast<Channel>(channel_index), state.channel_control.start_trigger);
UpdateChannelTransferEvent(static_cast<Channel>(channel_index)); UpdateChannelTransferEvent(static_cast<Channel>(channel_index));
return; return;
} }
@ -228,13 +233,7 @@ bool DMA::CanTransferChannel(Channel channel) const
if (!cs.channel_control.enable_busy) if (!cs.channel_control.enable_busy)
return false; return false;
if (!cs.request && channel != Channel::OTC) return cs.request;
return false;
if (cs.channel_control.sync_mode == SyncMode::Manual && !cs.channel_control.start_trigger)
return false;
return true;
} }
bool DMA::CanRunAnyChannels() const bool DMA::CanRunAnyChannels() const