blob: c74d3a5edc6072be68cbcda891297581efc80408 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
// Copyright 2024-2026, Amlal El Mahrouss (amlal@nekernel.org)
// Licensed under the Apache License, Version 2.0 (see LICENSE file)
// Official repository: https://github.com/ne-foss-org/nekernel
#ifndef KERNELKIT_CODEMGR_H
#define KERNELKIT_CODEMGR_H
#include <KernelKit/CoreProcessScheduler.h>
#include <KernelKit/IPEFDylibObject.h>
#include <KernelKit/PE32CodeMgr.h>
#include <KernelKit/PEFCodeMgr.h>
/// @file CodeMgr.h
/// @brief Code Manager header file.
/// @author Amlal El Mahrouss (amlal@nekernel.org)
namespace Kernel {
/// @brief Image process entrypoint.
typedef void (*rtl_start_kind)(void);
typedef void (*rtl_kstart_kind)(VoidPtr);
/// @brief C++ Constructor entrypoint.
typedef void (*rtl_cxx_ctor_kind)(void);
/// @brief C++ Destructor entrypoint.
typedef void (*rtl_cxx_dtor_kind)(void);
/// @brief Executes a new process from a function. Kernel code only.
/// @note This sets up a new stack, anything on the main function that calls the Kernel will not be
/// accessible.
/// @param main the start of the process.
/// @return The team's process id.
BOOL rtl_create_kernel_task(KernelTask& main, const KID& kid);
/// @brief Executes a new process from a function. User code only.
/// @note This sets up a new stack, anything on the main function that calls the Kernel will not be
/// accessible.
/// @param main the start of the process.
/// @return The team's process id.
ProcessID rtl_create_user_process(rtl_start_kind main, const Char* process_name);
} // namespace Kernel
#endif
|