mirror of
https://github.com/Atmosphere-NX/Atmosphere.git
synced 2025-05-13 06:34:23 -04:00
kern: clean up majority of TODOs
This commit is contained in:
parent
bea550ebce
commit
e1f3bb10a5
30 changed files with 112 additions and 85 deletions
|
@ -32,6 +32,19 @@ namespace ams::kern {
|
|||
void KSynchronizationObject::Finalize() {
|
||||
MESOSPHERE_ASSERT_THIS();
|
||||
|
||||
/* If auditing, ensure that the object has no waiters. */
|
||||
#if defined(MESOSPHERE_BUILD_FOR_AUDITING)
|
||||
{
|
||||
KScopedSchedulerLock sl;
|
||||
|
||||
auto end = this->end();
|
||||
for (auto it = this->begin(); it != end; ++it) {
|
||||
KThread *thread = std::addressof(*it);
|
||||
MESOSPHERE_LOG("KSynchronizationObject::Finalize(%p) with %p (id=%ld) waiting.\n", this, thread, thread->GetId());
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
this->OnFinalizeSynchronizationObject();
|
||||
KAutoObject::Finalize();
|
||||
}
|
||||
|
@ -39,7 +52,33 @@ namespace ams::kern {
|
|||
void KSynchronizationObject::DebugWaiters() {
|
||||
MESOSPHERE_ASSERT_THIS();
|
||||
|
||||
MESOSPHERE_TODO("Do useful debug operation here.");
|
||||
/* If debugging, dump the list of waiters. */
|
||||
#if defined(MESOSPHERE_BUILD_FOR_DEBUGGING)
|
||||
{
|
||||
KScopedSchedulerLock sl;
|
||||
|
||||
MESOSPHERE_RELEASE_LOG("Threads waiting on %p:\n", this);
|
||||
|
||||
bool has_waiters = false;
|
||||
auto end = this->end();
|
||||
for (auto it = this->begin(); it != end; ++it) {
|
||||
KThread *thread = std::addressof(*it);
|
||||
|
||||
if (KProcess *process = thread->GetOwnerProcess(); process != nullptr) {
|
||||
MESOSPHERE_RELEASE_LOG(" %p tid=%ld pid=%ld (%s)\n", thread, thread->GetId(), process->GetId(), process->GetName());
|
||||
} else {
|
||||
MESOSPHERE_RELEASE_LOG(" %p tid=%ld (Kernel)\n", thread, thread->GetId());
|
||||
}
|
||||
|
||||
has_waiters = true;
|
||||
}
|
||||
|
||||
/* If we didn't have any waiters, print so. */
|
||||
if (!has_waiters) {
|
||||
MESOSPHERE_RELEASE_LOG(" None\n");
|
||||
}
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
KSynchronizationObject::iterator KSynchronizationObject::RegisterWaitingThread(KThread *thread) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue