blob: 24fceb2b2eb20912152012c2f9a30ea5dda727e9 (
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
/* ========================================
Copyright (C) 2024-2025, Amlal El Mahrouss, licensed under the Apache 2.0 license.
======================================== */
#ifndef __EFI_API__
#define __EFI_API__
#include <FirmwareKit/EFI/EFI.h>
#include <FirmwareKit/Handover.h>
#include <KernelKit/MSDOS.h>
#include <KernelKit/PE.h>
#ifdef __BOOTZ__
// forward decl.
class BootTextWriter;
#define __BOOTKIT_NO_INCLUDE__ 1
#include <BootKit/BootKit.h>
#include <modules/CoreGfx/CoreGfx.h>
#endif // ifdef __BOOTZ__
inline EfiSystemTable* ST = nullptr;
inline EfiBootServices* BS = nullptr;
EXTERN_C void rt_cli();
EXTERN_C void rt_halt();
namespace Boot {
/// @brief Halt and clear interrut flag on x86.
/// @return
inline Void Stop() noexcept {
while (YES) {
rt_cli();
rt_halt();
}
}
/**
@brief Exit EFI API to let the OS load correctly.
Bascially frees everything we have in the EFI side.
*/
inline Void ExitBootServices(UInt64 MapKey, EfiHandlePtr ImageHandle) noexcept {
if (!ST) return;
ST->BootServices->ExitBootServices(ImageHandle, MapKey);
}
inline UInt32 Platform() noexcept {
return kPeMachineAMD64;
}
/***
* @brief Throw an error, stop execution as well.
* @param ErrorCode error code to be print.
* @param Reason reason to be print.
*/
inline void ThrowError(const EfiCharType* ErrorCode, const EfiCharType* Reason) noexcept {
ST->ConOut->OutputString(ST->ConOut, L"\r*** STOP ***\r");
ST->ConOut->OutputString(ST->ConOut, L"*** ERROR: ");
ST->ConOut->OutputString(ST->ConOut, ErrorCode);
ST->ConOut->OutputString(ST->ConOut, L" ***\r *** REASON: ");
ST->ConOut->OutputString(ST->ConOut, Reason);
ST->ConOut->OutputString(ST->ConOut, L" ***\r");
Boot::Stop();
}
} // namespace Boot
inline void fw_init_efi(EfiSystemTable* SystemTable) noexcept {
if (!SystemTable) return;
ST = SystemTable;
BS = ST->BootServices;
}
#ifdef __BOOTZ__
#include <BootKit/Platform.h>
#endif // ifdef __BOOTZ__
#endif /* ifndef __EFI_API__ */
|