From f3d931aa7cfaf96baef8383b59a8938779541ee7 Mon Sep 17 00:00:00 2001 From: Amlal EL Mahrouss Date: Thu, 15 Aug 2024 18:35:34 +0200 Subject: [IMP] Moved source code into dev/ folder. Signed-off-by: Amlal EL Mahrouss --- dev/Kernel/KernelKit/PEFSharedObject.hxx | 118 +++++++++++++++++++++++++++++++ 1 file changed, 118 insertions(+) create mode 100644 dev/Kernel/KernelKit/PEFSharedObject.hxx (limited to 'dev/Kernel/KernelKit/PEFSharedObject.hxx') diff --git a/dev/Kernel/KernelKit/PEFSharedObject.hxx b/dev/Kernel/KernelKit/PEFSharedObject.hxx new file mode 100644 index 00000000..2ce87c1d --- /dev/null +++ b/dev/Kernel/KernelKit/PEFSharedObject.hxx @@ -0,0 +1,118 @@ +/* + * ======================================================== + * + * Kernel + * Copyright ZKA Technologies., all rights reserved. + * + * ======================================================== + */ + +#ifndef __KERNELKIT_SHARED_OBJECT_HXX__ +#define __KERNELKIT_SHARED_OBJECT_HXX__ + +#include +#include +#include +#include + +namespace Kernel +{ + /// @brief Pure implementation, missing method/function handler. + extern "C" void __mh_purecall(void); + + /** + * @brief Shared Library class + * Load library from this class + */ + class PEFSharedObjectInterface final + { + public: + struct PEF_SHARED_OBJECT_TRAITS final + { + VoidPtr fImageObject{nullptr}; + VoidPtr fImageEntrypointOffset{nullptr}; + + Bool IsValid() { return fImageObject && fImageEntrypointOffset; } + }; + + public: + explicit PEFSharedObjectInterface() = default; + ~PEFSharedObjectInterface() = default; + + public: + NEWOS_COPY_DEFAULT(PEFSharedObjectInterface); + + private: + PEF_SHARED_OBJECT_TRAITS* fMounted{nullptr}; + + public: + PEF_SHARED_OBJECT_TRAITS** GetAddressOf() + { + return &fMounted; + } + + PEF_SHARED_OBJECT_TRAITS* Get() + { + return fMounted; + } + + public: + void Mount(PEF_SHARED_OBJECT_TRAITS* to_mount) + { + if (!to_mount || !to_mount->fImageObject) + return; + + fMounted = to_mount; + + if (fLoader && to_mount) + { + delete fLoader; + fLoader = nullptr; + } + + if (!fLoader) + { + fLoader = new PEFLoader(fMounted->fImageObject); + } + } + + void Unmount() + { + if (fMounted) + fMounted = nullptr; + }; + + template + SymbolType Load(const char* symbol_name, SizeT len, Int32 kind) + { + if (symbol_name == nullptr || *symbol_name == 0) + return nullptr; + if (len > kPathLen || len < 1) + return nullptr; + + auto ret = + reinterpret_cast(fLoader->FindSymbol(symbol_name, kind)); + + if (!ret) + { + if (kind == kPefCode) + return (VoidPtr)__mh_purecall; + + return nullptr; + } + + return ret; + } + + private: + PEFLoader* fLoader{nullptr}; + }; + + typedef PEFSharedObjectInterface* SharedObjectPtr; + + EXTERN_C SharedObjectPtr rtl_init_shared_object(PROCESS_HEADER_BLOCK* header); + EXTERN_C Void rtl_fini_shared_object(PROCESS_HEADER_BLOCK* header, SharedObjectPtr lib, Bool* successful); +} // namespace Kernel + +#endif /* ifndef __KERNELKIT_SHARED_OBJECT_HXX__ */ + -- cgit v1.2.3