blob: 75d46bb893bb7380b1f374014b33e6eb30d83744 (
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
|
/*
* ========================================================
*
* hCore
* Copyright 2024 Mahrouss Logic, all rights reserved.
*
* ========================================================
*/
#include <ArchKit/Arch.hpp>
namespace hCore::HAL
{
struct RegisterAMD64
{
UIntPtr base;
UShort limit;
};
void GDTLoader::Load(Register64 &gdt)
{
RegisterAMD64* reg = new RegisterAMD64();
MUST_PASS(reg);
reg->base = gdt.Base;
reg->limit = gdt.Limit;
rt_cli();
load_gdt(reg);
rt_sti();
}
void IDTLoader::Load(Register64 &idt)
{
RegisterAMD64* reg = new RegisterAMD64();
MUST_PASS(reg);
reg->base = idt.Base;
reg->limit = idt.Limit;
rt_cli();
load_idt(reg);
rt_sti();
}
void GDTLoader::Load(Ref<Register64> &gdt)
{
GDTLoader::Load(gdt.Leak());
}
void IDTLoader::Load(Ref<Register64> &idt)
{
IDTLoader::Load(idt.Leak());
}
} // namespace hCore::HAL
|