ksys: Implement more heap utilities

This commit is contained in:
Léo Lam 2020-09-04 22:38:06 +02:00
parent 3d371999a4
commit 977ff07c85
No known key found for this signature in database
GPG Key ID: 0DF30F9081000741
3 changed files with 53 additions and 5 deletions

View File

@ -90336,11 +90336,11 @@
0x00000071011f321c,sub_71011F321C,24,
0x00000071011f3234,sub_71011F3234,24,
0x00000071011f324c,sinitStageSelectMenu,172,
0x00000071011f32f8,getHeapOrCurrentHeap,48,
0x00000071011f3328,adjustHeap,44,
0x00000071011f3354,getCurrentHeap,16,
0x00000071011f3364,getDebugHeap,32,
0x00000071011f3384,getDebugHeap2,48,
0x00000071011f32f8,getHeapOrCurrentHeap,48,_ZN4ksys4util20getHeapOrCurrentHeapEPN4sead4HeapE
0x00000071011f3328,adjustHeap,44,_ZN4ksys4util23adjustHeapOrCurrentHeapEPN4sead4HeapE
0x00000071011f3354,getCurrentHeap,16,_ZN4ksys4util14getCurrentHeapEv
0x00000071011f3364,getDebugHeap,32,_ZN4ksys4util12getDebugHeapEv
0x00000071011f3384,getDebugHeap2,48,_ZN4ksys4util13getDebugHeap2Ev
0x00000071011f33b4,sub_71011F33B4,32,
0x00000071011f33d4,sub_71011F33D4,88,
0x00000071011f342c,sub_71011F342C,72,

Can't render this file because it is too large.

View File

@ -4,6 +4,26 @@
namespace ksys::util {
// Name, layout and purpose unknown; this is stubbed in release builds
class DebugHeapHolder {
SEAD_SINGLETON_DISPOSER(DebugHeapHolder)
public:
virtual ~DebugHeapHolder() = default;
virtual sead::Heap* getHeap() { return nullptr; }
};
SEAD_SINGLETON_DISPOSER_IMPL(DebugHeapHolder)
// Name, layout and purpose unknown; this is stubbed in release builds
class DebugHeapHolder2 {
SEAD_SINGLETON_DISPOSER(DebugHeapHolder2)
public:
virtual ~DebugHeapHolder2() = default;
virtual sead::Heap* getHeap() { return nullptr; }
};
SEAD_SINGLETON_DISPOSER_IMPL(DebugHeapHolder2)
sead::Heap* getHeapOrCurrentHeap(sead::Heap* heap) {
if (heap)
return heap;
@ -11,7 +31,29 @@ sead::Heap* getHeapOrCurrentHeap(sead::Heap* heap) {
if (!sead::ThreadMgr::instance())
return nullptr;
return getCurrentHeap();
}
void adjustHeapOrCurrentHeap(sead::Heap* heap) {
if (!heap)
heap = getCurrentHeap();
heap->adjust();
}
sead::Heap* getCurrentHeap() {
return sead::HeapMgr::instance()->getCurrentHeap();
}
sead::Heap* getDebugHeap() {
if (!DebugHeapHolder::instance())
return nullptr;
return DebugHeapHolder::instance()->getHeap();
}
sead::Heap* getDebugHeap2() {
if (DebugHeapHolder2::instance())
return DebugHeapHolder2::instance()->getHeap();
return getDebugHeap();
}
} // namespace ksys::util

View File

@ -11,4 +11,10 @@ namespace ksys::util {
/// Returns the specified heap if it is not null. Otherwise, this returns the current heap.
sead::Heap* getHeapOrCurrentHeap(sead::Heap* heap);
void adjustHeapOrCurrentHeap(sead::Heap* heap);
sead::Heap* getCurrentHeap();
sead::Heap* getDebugHeap();
sead::Heap* getDebugHeap2();
} // namespace ksys::util