summaryrefslogtreecommitdiffhomepage
path: root/HALKit/AMD64/ArchAMD64.cpp
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