KernelExplorer improved

This commit is contained in:
Nekotekina 2015-08-08 20:59:10 +03:00
parent e18db20630
commit eb63558c6d
5 changed files with 184 additions and 132 deletions

View File

@ -138,7 +138,7 @@ public:
return "Unknown"; return "Unknown";
} }
const char* ThreadStatusToString() const char* ThreadStatusToString() const
{ {
// TODO // TODO

View File

@ -6,7 +6,7 @@
#include "MFC.h" #include "MFC.h"
struct lv2_event_queue_t; struct lv2_event_queue_t;
struct spu_group_t; struct lv2_spu_group_t;
struct lv2_int_tag_t; struct lv2_int_tag_t;
// SPU Channels // SPU Channels
@ -581,7 +581,7 @@ public:
std::array<spu_int_ctrl_t, 3> int_ctrl; // SPU Class 0, 1, 2 Interrupt Management std::array<spu_int_ctrl_t, 3> int_ctrl; // SPU Class 0, 1, 2 Interrupt Management
std::weak_ptr<spu_group_t> tg; // SPU Thread Group std::weak_ptr<lv2_spu_group_t> tg; // SPU Thread Group
std::array<std::pair<u32, std::weak_ptr<lv2_event_queue_t>>, 32> spuq; // Event Queue Keys for SPU Thread std::array<std::pair<u32, std::weak_ptr<lv2_event_queue_t>>, 32> spuq; // Event Queue Keys for SPU Thread
std::weak_ptr<lv2_event_queue_t> spup[64]; // SPU Ports std::weak_ptr<lv2_event_queue_t> spup[64]; // SPU Ports

View File

@ -104,7 +104,7 @@ u32 spu_thread_initialize(u32 group_id, u32 spu_num, vm::ptr<sys_spu_image> img,
spu->custom_task = task; spu->custom_task = task;
const auto group = idm::get<spu_group_t>(group_id); const auto group = idm::get<lv2_spu_group_t>(group_id);
spu->tg = group; spu->tg = group;
group->threads[spu_num] = spu; group->threads[spu_num] = spu;
@ -140,7 +140,7 @@ s32 sys_spu_thread_initialize(vm::ptr<u32> thread, u32 group_id, u32 spu_num, vm
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(group_id); const auto group = idm::get<lv2_spu_group_t>(group_id);
if (!group) if (!group)
{ {
@ -237,7 +237,7 @@ s32 sys_spu_thread_group_create(vm::ptr<u32> id, u32 num, s32 prio, vm::ptr<sys_
sys_spu.Todo("Unsupported SPU Thread Group type (0x%x)", attr->type); sys_spu.Todo("Unsupported SPU Thread Group type (0x%x)", attr->type);
} }
*id = idm::make<spu_group_t>(std::string{ attr->name.get_ptr(), attr->nsize - 1 }, num, prio, attr->type, attr->ct); *id = idm::make<lv2_spu_group_t>(std::string{ attr->name.get_ptr(), attr->nsize - 1 }, num, prio, attr->type, attr->ct);
return CELL_OK; return CELL_OK;
} }
@ -248,7 +248,7 @@ s32 sys_spu_thread_group_destroy(u32 id)
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(id); const auto group = idm::get<lv2_spu_group_t>(id);
if (!group) if (!group)
{ {
@ -272,7 +272,7 @@ s32 sys_spu_thread_group_destroy(u32 id)
} }
group->state = SPU_THREAD_GROUP_STATUS_NOT_INITIALIZED; // hack group->state = SPU_THREAD_GROUP_STATUS_NOT_INITIALIZED; // hack
idm::remove<spu_group_t>(id); idm::remove<lv2_spu_group_t>(id);
return CELL_OK; return CELL_OK;
} }
@ -283,7 +283,7 @@ s32 sys_spu_thread_group_start(u32 id)
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(id); const auto group = idm::get<lv2_spu_group_t>(id);
if (!group) if (!group)
{ {
@ -345,7 +345,7 @@ s32 sys_spu_thread_group_suspend(u32 id)
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(id); const auto group = idm::get<lv2_spu_group_t>(id);
if (!group) if (!group)
{ {
@ -395,7 +395,7 @@ s32 sys_spu_thread_group_resume(u32 id)
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(id); const auto group = idm::get<lv2_spu_group_t>(id);
if (!group) if (!group)
{ {
@ -438,7 +438,7 @@ s32 sys_spu_thread_group_yield(u32 id)
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(id); const auto group = idm::get<lv2_spu_group_t>(id);
if (!group) if (!group)
{ {
@ -463,7 +463,7 @@ s32 sys_spu_thread_group_terminate(u32 id, s32 value)
// seems the id can be either SPU Thread Group or SPU Thread // seems the id can be either SPU Thread Group or SPU Thread
const auto thread = idm::get<SPUThread>(id); const auto thread = idm::get<SPUThread>(id);
const auto group = thread ? thread->tg.lock() : idm::get<spu_group_t>(id); const auto group = thread ? thread->tg.lock() : idm::get<lv2_spu_group_t>(id);
if (!group && !thread) if (!group && !thread)
{ {
@ -515,7 +515,7 @@ s32 sys_spu_thread_group_join(u32 id, vm::ptr<u32> cause, vm::ptr<u32> status)
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(id); const auto group = idm::get<lv2_spu_group_t>(id);
if (!group) if (!group)
{ {
@ -794,7 +794,7 @@ s32 sys_spu_thread_group_connect_event(u32 id, u32 eq, u32 et)
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(id); const auto group = idm::get<lv2_spu_group_t>(id);
const auto queue = idm::get<lv2_event_queue_t>(eq); const auto queue = idm::get<lv2_event_queue_t>(eq);
if (!group || !queue) if (!group || !queue)
@ -850,7 +850,7 @@ s32 sys_spu_thread_group_disconnect_event(u32 id, u32 et)
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(id); const auto group = idm::get<lv2_spu_group_t>(id);
if (!group) if (!group)
{ {
@ -1038,7 +1038,7 @@ s32 sys_spu_thread_group_connect_event_all_threads(u32 id, u32 eq, u64 req, vm::
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(id); const auto group = idm::get<lv2_spu_group_t>(id);
const auto queue = idm::get<lv2_event_queue_t>(eq); const auto queue = idm::get<lv2_event_queue_t>(eq);
if (!group || !queue) if (!group || !queue)
@ -1109,7 +1109,7 @@ s32 sys_spu_thread_group_disconnect_event_all_threads(u32 id, u8 spup)
LV2_LOCK; LV2_LOCK;
const auto group = idm::get<spu_group_t>(id); const auto group = idm::get<lv2_spu_group_t>(id);
if (!group) if (!group)
{ {

View File

@ -143,7 +143,7 @@ enum : u32
class SPUThread; class SPUThread;
struct spu_group_t struct lv2_spu_group_t
{ {
const std::string name; const std::string name;
const u32 num; // SPU Number const u32 num; // SPU Number
@ -165,7 +165,7 @@ struct spu_group_t
std::weak_ptr<lv2_event_queue_t> ep_exception; // TODO: SYS_SPU_THREAD_GROUP_EVENT_EXCEPTION std::weak_ptr<lv2_event_queue_t> ep_exception; // TODO: SYS_SPU_THREAD_GROUP_EVENT_EXCEPTION
std::weak_ptr<lv2_event_queue_t> ep_sysmodule; // TODO: SYS_SPU_THREAD_GROUP_EVENT_SYSTEM_MODULE std::weak_ptr<lv2_event_queue_t> ep_sysmodule; // TODO: SYS_SPU_THREAD_GROUP_EVENT_SYSTEM_MODULE
spu_group_t(std::string name, u32 num, s32 prio, s32 type, u32 ct) lv2_spu_group_t(std::string name, u32 num, s32 prio, s32 type, u32 ct)
: name(name) : name(name)
, num(num) , num(num)
, prio(prio) , prio(prio)

View File

@ -14,8 +14,11 @@
#include "Emu/SysCalls/lv2/sys_semaphore.h" #include "Emu/SysCalls/lv2/sys_semaphore.h"
#include "Emu/SysCalls/lv2/sys_event.h" #include "Emu/SysCalls/lv2/sys_event.h"
#include "Emu/SysCalls/lv2/sys_event_flag.h" #include "Emu/SysCalls/lv2/sys_event_flag.h"
#include "Emu/SysCalls/lv2/sys_rwlock.h"
#include "Emu/SysCalls/lv2/sys_prx.h" #include "Emu/SysCalls/lv2/sys_prx.h"
#include "Emu/SysCalls/lv2/sys_memory.h" #include "Emu/SysCalls/lv2/sys_memory.h"
#include "Emu/SysCalls/lv2/sys_mmapper.h"
#include "Emu/SysCalls/lv2/sys_spu.h"
#include "KernelExplorer.h" #include "KernelExplorer.h"
@ -53,12 +56,10 @@ KernelExplorer::KernelExplorer(wxWindow* parent)
void KernelExplorer::Update() void KernelExplorer::Update()
{ {
char name[4096];
m_tree->DeleteAllItems(); m_tree->DeleteAllItems();
const u32 total_memory_usage = vm::get(vm::user_space)->used.load(); const u32 total_memory_usage = vm::get(vm::user_space)->used.load();
const auto& root = m_tree->AddRoot(fmt::Format("Process, ID = 0x00000001, Total Memory Usage = 0x%x (%0.2f MB)", total_memory_usage, (float)total_memory_usage / (1024 * 1024))); const auto& root = m_tree->AddRoot(fmt::format("Process, ID = 0x00000001, Total Memory Usage = 0x%x (%0.2f MB)", total_memory_usage, (float)total_memory_usage / (1024 * 1024)));
union name64 union name64
{ {
@ -79,174 +80,225 @@ void KernelExplorer::Update()
// TODO: FileSystem // TODO: FileSystem
// Semaphores // Semaphores
if (u32 count = idm::get_count<lv2_sema_t>()) const auto sema_map = idm::get_map<lv2_sema_t>();
{
sprintf(name, "Semaphores (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<lv2_sema_t>()) if (sema_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("Semaphores (%zu)", sema_map.size()));
for (const auto& data : sema_map)
{ {
const auto& sema = *data.second; const auto& sema = *data.second;
sprintf(name, "Semaphore: ID = 0x%x '%s', Count = %d, Max Count = %d, Waiters = %#llx", data.first, &name64(sema.name), sema.value.load(), sema.max, sema.sq.size());
m_tree->AppendItem(node, name); m_tree->AppendItem(node, fmt::format("Semaphore: ID = 0x%08x '%s', Count = %d, Max Count = %d, Waiters = %#zu", data.first,
&name64(sema.name), sema.value.load(), sema.max, sema.sq.size()));
} }
} }
// Mutexes // Mutexes
if (u32 count = idm::get_count<lv2_mutex_t>()) const auto mutex_map = idm::get_map<lv2_mutex_t>();
{
sprintf(name, "Mutexes (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<lv2_mutex_t>()) if (mutex_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("Mutexes (%zu)", mutex_map.size()));
for (const auto& data : mutex_map)
{ {
sprintf(name, "Mutex: ID = 0x%x '%s'", data.first, &name64(data.second->name)); const auto& mutex = *data.second;
m_tree->AppendItem(node, name);
m_tree->AppendItem(node, fmt::format("Mutex: ID = 0x%08x '%s'", data.first,
&name64(mutex.name)));
} }
} }
// Light Weight Mutexes // Lightweight Mutexes
if (u32 count = idm::get_count<lv2_lwmutex_t>()) const auto lwm_map = idm::get_map<lv2_lwmutex_t>();
{
sprintf(name, "Lightweight Mutexes (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<lv2_lwmutex_t>()) if (lwm_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("Lightweight Mutexes (%zu)", lwm_map.size()));
for (const auto& data : lwm_map)
{ {
sprintf(name, "Lightweight Mutex: ID = 0x%x '%s'", data.first, &name64(data.second->name)); const auto& lwm = *data.second;
m_tree->AppendItem(node, name);
m_tree->AppendItem(node, fmt::format("LWMutex: ID = 0x%08x '%s'", data.first,
&name64(lwm.name)));
} }
} }
// Condition Variables // Condition Variables
if (u32 count = idm::get_count<lv2_cond_t>()) const auto cond_map = idm::get_map<lv2_cond_t>();
{
sprintf(name, "Condition Variables (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<lv2_cond_t>()) if (cond_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("Condition Variables (%zu)", cond_map.size()));
for (const auto& data : cond_map)
{ {
sprintf(name, "Condition Variable: ID = 0x%x '%s'", data.first, &name64(data.second->name)); const auto& cond = *data.second;
m_tree->AppendItem(node, name);
m_tree->AppendItem(node, fmt::format("Cond: ID = 0x%08x '%s'", data.first,
&name64(cond.name)));
} }
} }
// Light Weight Condition Variables // Lightweight Condition Variables
if (u32 count = idm::get_count<lv2_lwcond_t>()) const auto lwc_map = idm::get_map<lv2_lwcond_t>();
{
sprintf(name, "Lightweight Condition Variables (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<lv2_lwcond_t>()) if (lwc_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("Lightweight Condition Variables (%zu)", lwc_map.size()));
for (const auto& data : lwc_map)
{ {
sprintf(name, "Lightweight Condition Variable: ID = 0x%x '%s'", data.first, &name64(data.second->name)); const auto& lwc = *data.second;
m_tree->AppendItem(node, name);
m_tree->AppendItem(node, fmt::format("LWCond: ID = 0x%08x '%s'", data.first,
&name64(lwc.name)));
} }
} }
// Event Queues // Event Queues
if (u32 count = idm::get_count<lv2_event_queue_t>()) const auto eq_map = idm::get_map<lv2_event_queue_t>();
{
sprintf(name, "Event Queues (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<lv2_event_queue_t>()) if (eq_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("Event Queues (%zu)", eq_map.size()));
for (const auto& data : eq_map)
{ {
sprintf(name, "Event Queue: ID = 0x%x '%s', Key = %#llx", data.first, &name64(data.second->name), data.second->key); const auto& eq = *data.second;
m_tree->AppendItem(node, name);
m_tree->AppendItem(node, fmt::format("Event Queue: ID = 0x%08x '%s', %s, Key = %#llx, Events = %zu/%d, Waiters = %zu", data.first,
&name64(eq.name), eq.type == SYS_SPU_QUEUE ? "SPU" : "PPU", eq.key, eq.events.size(), eq.size, eq.sq.size()));
} }
} }
// Event Ports // Event Ports
if (u32 count = idm::get_count<lv2_event_port_t>()) const auto ep_map = idm::get_map<lv2_event_port_t>();
if (ep_map.size())
{ {
sprintf(name, "Event Ports (%d)", count); const auto& node = m_tree->AppendItem(root, fmt::format("Event Ports (%zu)", ep_map.size()));
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<lv2_event_port_t>()) for (const auto& data : ep_map)
{ {
sprintf(name, "Event Port: ID = 0x%x, Name = %#llx", data.first, data.second->name); const auto& ep = *data.second;
m_tree->AppendItem(node, name);
}
}
// Modules m_tree->AppendItem(node, fmt::format("Event Port: ID = 0x%08x, Name = %#llx", data.first,
if (u32 count = idm::get_count<lv2_prx_t>()) ep.name));
{
sprintf(name, "Modules (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
//sprintf(name, "Segment List (%l)", 2 * objects.size()); // TODO: Assuming 2 segments per PRX file is not good
//m_tree->AppendItem(node, name);
for (const auto id : idm::get_set<lv2_prx_t>())
{
sprintf(name, "PRX: ID = 0x%x", id);
m_tree->AppendItem(node, name);
}
}
// Memory Containers
if (u32 count = idm::get_count<lv2_memory_container_t>())
{
sprintf(name, "Memory Containers (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto id : idm::get_set<lv2_memory_container_t>())
{
sprintf(name, "Memory Container: ID = 0x%x", id);
m_tree->AppendItem(node, name);
} }
} }
// Event Flags // Event Flags
if (u32 count = idm::get_count<lv2_event_flag_t>()) const auto ef_map = idm::get_map<lv2_event_flag_t>();
{
sprintf(name, "Event Flags (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<lv2_event_flag_t>()) if (ef_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("Event Flags (%zu)", ef_map.size()));
for (const auto& data : ef_map)
{ {
sprintf(name, "Event Flag: ID = 0x%x", data.first); const auto& ef = *data.second;
m_tree->AppendItem(node, name);
m_tree->AppendItem(node, fmt::format("Event Flag: ID = 0x%08x", data.first));
}
}
// Reader/writer Locks
const auto rwlock_map = idm::get_map<lv2_rwlock_t>();
if (rwlock_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("Reader/writer Locks (%zu)", rwlock_map.size()));
for (const auto& data : rwlock_map)
{
const auto& rwlock = *data.second;
m_tree->AppendItem(node, fmt::format("RWLock: ID = 0x%08x", data.first));
}
}
// PRX Libraries
const auto prx_map = idm::get_map<lv2_prx_t>();
if (prx_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("PRX Libraries (%zu)", prx_map.size()));
for (const auto& data : prx_map)
{
const auto& prx = *data.second;
m_tree->AppendItem(node, fmt::format("PRX: ID = 0x%08x", data.first));
}
}
// Memory Containers
const auto ct_map = idm::get_map<lv2_memory_container_t>();
if (ct_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("Memory Containers (%zu)", ct_map.size()));
for (const auto& data : ct_map)
{
const auto& ct = *data.second;
m_tree->AppendItem(node, fmt::format("Memory Container: ID = 0x%08x", data.first));
}
}
// Memory Objects
const auto mem_map = idm::get_map<lv2_memory_t>();
if (mem_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("Memory Objects (%zu)", mem_map.size()));
for (const auto& data : mem_map)
{
const auto& mem = *data.second;
m_tree->AppendItem(node, fmt::format("Memory Object: ID = 0x%08x", data.first));
} }
} }
// PPU Threads // PPU Threads
if (u32 count = idm::get_count<PPUThread>()) const auto ppu_map = idm::get_map<PPUThread>();
{
sprintf(name, "PPU Threads (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<PPUThread>()) if (ppu_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("PPU Threads (%zu)", ppu_map.size()));
for (const auto& data : ppu_map)
{ {
sprintf(name, "Thread: ID = 0x%08x '%s', - %s", data.first, data.second->get_name().c_str(), data.second->ThreadStatusToString()); const auto& ppu = *data.second;
m_tree->AppendItem(node, name);
m_tree->AppendItem(node, fmt::format("PPU Thread: ID = 0x%08x '%s', - %s", data.first,
ppu.get_name().c_str(), ppu.ThreadStatusToString()));
} }
} }
if (u32 count = idm::get_count<SPUThread>()) // SPU Thread Groups
{ const auto spu_map = idm::get_map<lv2_spu_group_t>();
sprintf(name, "SPU Threads (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<SPUThread>()) if (spu_map.size())
{
const auto& node = m_tree->AppendItem(root, fmt::format("SPU Thread Groups (%d)", spu_map.size()));
for (const auto& data : spu_map)
{ {
sprintf(name, "Thread: ID = 0x%08x '%s', - %s", data.first, data.second->get_name().c_str(), data.second->ThreadStatusToString()); const auto& tg = *data.second;
m_tree->AppendItem(node, name);
m_tree->AppendItem(node, fmt::format("SPU Thread Group: ID = 0x%08x '%s'", data.first,
tg.name.c_str()));
} }
} }
if (u32 count = idm::get_count<RawSPUThread>()) // RawSPU Threads (TODO)
{
sprintf(name, "RawSPU Threads (%d)", count);
const auto& node = m_tree->AppendItem(root, name);
for (const auto& data : idm::get_map<RawSPUThread>())
{
sprintf(name, "Thread: ID = 0x%08x '%s', - %s", data.first, data.second->get_name().c_str(), data.second->ThreadStatusToString());
m_tree->AppendItem(node, name);
}
}
m_tree->Expand(root); m_tree->Expand(root);
} }