From 7714e311af10b3a7ec4f270e26d84fc5aed521ba Mon Sep 17 00:00:00 2001 From: Amlal El Mahrouss Date: Sun, 16 Mar 2025 04:34:26 +0100 Subject: FIX: IPEFDylibObject.cc: delete dll_Obj->Get() too, when fBlob is NULL. Signed-off-by: Amlal El Mahrouss --- dev/Kernel/src/IPEFDylibObject.cc | 6 ++++++ dev/Kernel/src/MemoryMgr.cc | 2 +- 2 files changed, 7 insertions(+), 1 deletion(-) (limited to 'dev/Kernel/src') diff --git a/dev/Kernel/src/IPEFDylibObject.cc b/dev/Kernel/src/IPEFDylibObject.cc index 4824cca1..e994ad29 100644 --- a/dev/Kernel/src/IPEFDylibObject.cc +++ b/dev/Kernel/src/IPEFDylibObject.cc @@ -56,6 +56,8 @@ EXTERN_C IDylibRef rtl_init_dylib(UserProcess& process) if (!dll_obj->Get()) { tls_delete_class(dll_obj); + dll_obj = nullptr; + process.Crash(); return nullptr; @@ -66,7 +68,11 @@ EXTERN_C IDylibRef rtl_init_dylib(UserProcess& process) if (!dll_obj->Get()->ImageObject) { + delete dll_obj->Get(); + tls_delete_class(dll_obj); + dll_obj = nullptr; + process.Crash(); return nullptr; diff --git a/dev/Kernel/src/MemoryMgr.cc b/dev/Kernel/src/MemoryMgr.cc index cea772f0..4e13ea15 100644 --- a/dev/Kernel/src/MemoryMgr.cc +++ b/dev/Kernel/src/MemoryMgr.cc @@ -81,7 +81,7 @@ namespace NeOS auto base_heap = ((IntPtr)heap_ptr) - sizeof(Detail::HEAP_INFORMATION_BLOCK); /// Add that check in case we're having an integer underflow. /// - + if (base_heap < 0) { return false; -- cgit v1.2.3