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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
|
/* -------------------------------------------
Copyright Mahrouss Logic
------------------------------------------- */
/***********************************************************************************/
/// @file Boot.hxx
/// @brief Bootloader API.
/***********************************************************************************/
#pragma once
class BTextWriter;
class BFileReader;
class BFileRunner;
class BVersionString;
#include <BootKit/Arch/ATA.hxx>
#include <CompilerKit/Version.hxx>
#include <FirmwareKit/EFI.hxx>
#include <NewKit/Defines.hpp>
#include <FirmwareKit/EPM.hxx>
using namespace NewOS;
typedef Char *PEFImagePtr;
typedef Char *PEImagePtr;
enum {
kSegmentCode = 2,
kSegmentData = 4,
kSegmentBss = 6,
};
typedef WideChar CharacterTypeUTF16;
typedef Char CharacterTypeUTF8;
/**
* @brief BootKit Text Writer class
* Writes to UEFI StdOut.
*/
class BTextWriter final {
BTextWriter &_Write(const Long &num);
public:
BTextWriter &Write(const Long &num);
BTextWriter &Write(const UChar *str);
BTextWriter &Write(const CharacterTypeUTF16 *str);
BTextWriter &WriteCharacter(CharacterTypeUTF16 c);
public:
explicit BTextWriter() = default;
~BTextWriter() = default;
public:
BTextWriter &operator=(const BTextWriter &) = default;
BTextWriter(const BTextWriter &) = default;
};
NewOS::SizeT BCopyMem(CharacterTypeUTF16 *dest, CharacterTypeUTF16 *src,
const NewOS::SizeT len);
NewOS::SizeT BSetMem(CharacterTypeUTF8 *src, const CharacterTypeUTF8 byte,
const NewOS::SizeT len);
/// String length functions.
NewOS::SizeT BStrLen(const CharacterTypeUTF16 *ptr);
NewOS::SizeT BSetMem(CharacterTypeUTF16 *src, const CharacterTypeUTF16 byte,
const NewOS::SizeT len);
/**
* @brief BootKit File Reader class
* Reads the Firmware Boot partition and filesystem.
*/
class BFileReader final {
public:
explicit BFileReader(const CharacterTypeUTF16 *path, EfiHandlePtr ImageHandle);
~BFileReader();
Void ReadAll();
enum {
kOperationOkay,
kNotSupported,
kEmptyDirectory,
kNoSuchEntry,
kIsDirectory,
kCount,
};
Int32 &Error() { return mErrorCode; }
VoidPtr Blob() { return mBlob; }
EfiFileProtocolPtr File() { return mFile; }
UInt64 &Size() { return mSizeFile; }
UInt64 &Size(const UInt64 &Sz) {
mSizeFile = Sz;
return mSizeFile;
}
public:
BFileReader &operator=(const BFileReader &) = default;
BFileReader(const BFileReader &) = default;
private:
Int32 mErrorCode{kOperationOkay};
VoidPtr mBlob{nullptr};
CharacterTypeUTF16 mPath[kPathLen];
BTextWriter mWriter;
EfiFileProtocol *mFile{nullptr};
UInt64 mSizeFile{0};
};
typedef UInt8 *BlobType;
#define kMaxReadSize (320)
/***********************************************************************************/
/// Include other APIs.
/***********************************************************************************/
#include <BootKit/Platform.hxx>
#include <BootKit/Protocol.hxx>
/***********************************************************************************/
/// Provide some useful processor features.
/***********************************************************************************/
#ifdef __EFI_x86_64__
inline void Out8(UInt16 port, UInt8 value) {
asm volatile("outb %%al, %1" : : "a"(value), "Nd"(port) : "memory");
}
inline void Out16(UInt16 port, UInt16 value) {
asm volatile("outw %%ax, %1" : : "a"(value), "Nd"(port) : "memory");
}
inline void Out32(UInt16 port, UInt32 value) {
asm volatile("outl %%eax, %1" : : "a"(value), "Nd"(port) : "memory");
}
inline UInt8 In8(UInt16 port) {
UInt8 value;
asm volatile("inb %1, %%al" : "=a"(value) : "Nd"(port) : "memory");
return value;
}
inline UInt16 In16(UInt16 port) {
UInt16 value;
asm volatile("inw %%dx, %%ax" : "=a"(value) : "d"(port));
return value;
}
inline UInt32 In32(UInt16 port) {
UInt32 value;
asm volatile("inl %1, %%eax" : "=a"(value) : "Nd"(port) : "memory");
return value;
}
inline Void rt_hlt() {
asm volatile("hlt");
}
#endif // __EFI_x86_64__
/***********************************************************************************/
/// Framebuffer.
/***********************************************************************************/
#define RGB(R, G, B) (UInt32)(0x##R##G##B)
const UInt32 kRgbRed = 0x000000FF;
const UInt32 kRgbGreen = 0x0000FF00;
const UInt32 kRgbBlue = 0x00FF0000;
const UInt32 kRgbBlack = 0x00000000;
const UInt32 kRgbWhite = 0x00FFFFFF;
/** QT GOP and related. */
inline EfiGraphicsOutputProtocol *kGop;
inline UInt16 kStride;
inline EfiGUID kGopGuid;
/**
@brief Inits the QuickTemplate GUI framework.
*/
inline Void InitGOP() noexcept {
kGopGuid = EfiGUID(EFI_GRAPHICS_OUTPUT_PROTOCOL_GUID);
kGop = nullptr;
extern EfiBootServices *BS;
BS->LocateProtocol(&kGopGuid, nullptr, (VoidPtr *)&kGop);
kStride = 4;
}
class BVersionString final {
public:
static const CharacterTypeUTF16 *Shared() { return BOOTLOADER_VERSION; }
};
EXTERN_C Boolean boot_write_newfs_partition(const Char* namePart, SizeT namePartLength, BDeviceATA* ataInterface);
|