XThread free stack on destruction
This commit is contained in:
parent
07d31862f1
commit
621d3f8abb
|
@ -89,6 +89,7 @@ XThread::~XThread() {
|
||||||
kernel_state()->memory()->SystemHeapFree(scratch_address_);
|
kernel_state()->memory()->SystemHeapFree(scratch_address_);
|
||||||
kernel_state()->memory()->SystemHeapFree(tls_address_);
|
kernel_state()->memory()->SystemHeapFree(tls_address_);
|
||||||
kernel_state()->memory()->SystemHeapFree(pcr_address_);
|
kernel_state()->memory()->SystemHeapFree(pcr_address_);
|
||||||
|
FreeStack();
|
||||||
|
|
||||||
if (thread_) {
|
if (thread_) {
|
||||||
// TODO(benvanik): platform kill
|
// TODO(benvanik): platform kill
|
||||||
|
@ -214,7 +215,7 @@ bool XThread::AllocateStack(uint32_t size) {
|
||||||
auto heap = memory()->LookupHeap(0x40000000);
|
auto heap = memory()->LookupHeap(0x40000000);
|
||||||
|
|
||||||
auto alignment = heap->page_size();
|
auto alignment = heap->page_size();
|
||||||
auto padding = heap->page_size() * 2; // Guard pages
|
auto padding = heap->page_size() * 2; // Guard page size * 2
|
||||||
size = xe::round_up(size, alignment);
|
size = xe::round_up(size, alignment);
|
||||||
auto actual_size = size + padding;
|
auto actual_size = size + padding;
|
||||||
|
|
||||||
|
@ -241,6 +242,18 @@ bool XThread::AllocateStack(uint32_t size) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void XThread::FreeStack() {
|
||||||
|
if (stack_alloc_base_) {
|
||||||
|
auto heap = memory()->LookupHeap(0x40000000);
|
||||||
|
heap->Release(stack_alloc_base_);
|
||||||
|
|
||||||
|
stack_alloc_base_ = 0;
|
||||||
|
stack_alloc_size_ = 0;
|
||||||
|
stack_base_ = 0;
|
||||||
|
stack_limit_ = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
X_STATUS XThread::Create() {
|
X_STATUS XThread::Create() {
|
||||||
// Thread kernel object.
|
// Thread kernel object.
|
||||||
if (!CreateNative<X_KTHREAD>()) {
|
if (!CreateNative<X_KTHREAD>()) {
|
||||||
|
|
|
@ -196,6 +196,7 @@ class XThread : public XObject {
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool AllocateStack(uint32_t size);
|
bool AllocateStack(uint32_t size);
|
||||||
|
void FreeStack();
|
||||||
void InitializeGuestObject();
|
void InitializeGuestObject();
|
||||||
|
|
||||||
bool StepToAddress(uint32_t pc);
|
bool StepToAddress(uint32_t pc);
|
||||||
|
|
Loading…
Reference in New Issue