mirror of
				https://git.suyu.dev/suyu/suyu
				synced 2025-10-26 13:42:48 -05:00 
			
		
		
		
	kernel/thread: Unify wait synchronization types
This is a holdover from Citra, where the 3DS has both WaitSynchronization1 and WaitSynchronizationN. The switch only has one form of wait synchronizing (literally WaitSynchonization). This allows us to throw out code that doesn't apply at all to the Switch kernel. Because of this unnecessary dichotomy within the wait synchronization utilities, we were also neglecting to properly handle waiting on multiple objects. While we're at it, we can also scrub out any lingering references to WaitSynchronization1/WaitSynchronizationN in comments, and change them to WaitSynchronization (or remove them if the mention no longer applies).
This commit is contained in:
		| @@ -227,8 +227,7 @@ QString WaitTreeThread::GetText() const { | ||||
|     case Kernel::ThreadStatus::WaitIPC: | ||||
|         status = tr("waiting for IPC reply"); | ||||
|         break; | ||||
|     case Kernel::ThreadStatus::WaitSynchAll: | ||||
|     case Kernel::ThreadStatus::WaitSynchAny: | ||||
|     case Kernel::ThreadStatus::WaitSynch: | ||||
|         status = tr("waiting for objects"); | ||||
|         break; | ||||
|     case Kernel::ThreadStatus::WaitMutex: | ||||
| @@ -269,8 +268,7 @@ QColor WaitTreeThread::GetColor() const { | ||||
|         return QColor(Qt::GlobalColor::darkRed); | ||||
|     case Kernel::ThreadStatus::WaitSleep: | ||||
|         return QColor(Qt::GlobalColor::darkYellow); | ||||
|     case Kernel::ThreadStatus::WaitSynchAll: | ||||
|     case Kernel::ThreadStatus::WaitSynchAny: | ||||
|     case Kernel::ThreadStatus::WaitSynch: | ||||
|     case Kernel::ThreadStatus::WaitMutex: | ||||
|     case Kernel::ThreadStatus::WaitCondVar: | ||||
|     case Kernel::ThreadStatus::WaitArb: | ||||
| @@ -325,10 +323,9 @@ std::vector<std::unique_ptr<WaitTreeItem>> WaitTreeThread::GetChildren() const { | ||||
|         list.push_back(std::make_unique<WaitTreeText>(tr("not waiting for mutex"))); | ||||
|     } | ||||
|  | ||||
|     if (thread.GetStatus() == Kernel::ThreadStatus::WaitSynchAny || | ||||
|         thread.GetStatus() == Kernel::ThreadStatus::WaitSynchAll) { | ||||
|     if (thread.GetStatus() == Kernel::ThreadStatus::WaitSynch) { | ||||
|         list.push_back(std::make_unique<WaitTreeObjectList>(thread.GetWaitObjects(), | ||||
|                                                             thread.IsSleepingOnWaitAll())); | ||||
|                                                             thread.IsSleepingOnWait())); | ||||
|     } | ||||
|  | ||||
|     list.push_back(std::make_unique<WaitTreeCallstack>(thread)); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Lioncash
					Lioncash