WaitSynchronizationN: Handle case where handle_count is invalid.

This commit is contained in:
bunnei 2015-01-17 12:35:55 -05:00
parent 064be2b86f
commit f5c6d367c9

View file

@ -148,8 +148,12 @@ static Result WaitSynchronizationN(s32* out, Handle* handles, s32 handle_count,
bool wait_all_succeeded = false; bool wait_all_succeeded = false;
int handle_index = 0; int handle_index = 0;
// If handles were passed in, iterate through them and wait/acquire the objects as needed // Negative handle_count is invalid
if (handle_count > 0) { if (handle_count < 0)
return ResultCode(ErrorDescription::OutOfRange, ErrorModule::OS, ErrorSummary::InvalidArgument, ErrorLevel::Usage).raw;
// If handle_count is non-zero, iterate through them and wait/acquire the objects as needed
if (handle_count != 0) {
while (handle_index < handle_count) { while (handle_index < handle_count) {
SharedPtr<Kernel::Object> object = Kernel::g_handle_table.GetGeneric(handles[handle_index]); SharedPtr<Kernel::Object> object = Kernel::g_handle_table.GetGeneric(handles[handle_index]);
if (object == nullptr) if (object == nullptr)
@ -172,7 +176,7 @@ static Result WaitSynchronizationN(s32* out, Handle* handles, s32 handle_count,
handle_index++; handle_index++;
} }
}else { } else {
// If no handles were passed in, put the thread to sleep only when wait_all=false // If no handles were passed in, put the thread to sleep only when wait_all=false
// NOTE: This is supposed to deadlock if no timeout was specified // NOTE: This is supposed to deadlock if no timeout was specified
if (!wait_all) { if (!wait_all) {