os-k/kaleid/kernel/mm/gdt.c

112 lines
4.1 KiB
C
Raw Normal View History

2019-03-26 18:20:23 +01:00
//----------------------------------------------------------------------------//
// GNU GPL OS/K //
// //
// Desc: Mapping and checking memory related functions //
// //
// //
// Copyright © 2018-2019 The OS/K Team //
// //
// This file is part of OS/K. //
// //
// OS/K is free software: you can redistribute it and/or modify //
// it under the terms of the GNU General Public License as published by //
// the Free Software Foundation, either version 3 of the License, or //
// any later version. //
// //
// OS/K is distributed in the hope that it will be useful, //
// but WITHOUT ANY WARRANTY//without even the implied warranty of //
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
// GNU General Public License for more details. //
// //
// You should have received a copy of the GNU General Public License //
// along with OS/K. If not, see <https://www.gnu.org/licenses/>. //
//----------------------------------------------------------------------------//
2019-05-13 23:22:27 +02:00
#include <mm/mm.h>
2019-03-26 18:20:23 +01:00
2019-05-19 23:33:34 +02:00
//Tss_t tssEntry = { 0 };
GdtPtr_t gdtPtr;
2019-05-13 18:07:45 +02:00
2019-05-19 23:33:34 +02:00
/* static void SetGdtEntry(int index, uint base, uint limit, uchar access) */
/* { */
/* gdtEntries[index].lowBase = (base & 0xFFFF); */
/* gdtEntries[index].middleBase = (base >> 16) & 0xFF; */
/* gdtEntries[index].highBase = (base >> 24) & 0xFF; */
2019-05-13 18:07:45 +02:00
2019-05-19 23:33:34 +02:00
/* gdtEntries[index].lowLimit = (limit & 0xFFFF); */
/* gdtEntries[index].granularity = (limit >> 16) & 0x0F; */
2019-05-13 18:07:45 +02:00
2019-05-19 23:33:34 +02:00
/* gdtEntries[index].granularity |= 0xA0; */
2019-05-13 18:07:45 +02:00
2019-05-19 23:33:34 +02:00
/* // 0x10 is system */
/* // 0x80 is present */
/* gdtEntries[index].access = access | 0x10 | 0x80; */
/* } */
2019-05-13 18:07:45 +02:00
2019-05-19 23:33:34 +02:00
/* static void SetTssEntry(uchar index, ulong base, ulong limit) */
/* { */
/* TssDescriptor_t tssDesc = { 0 }; */
2019-05-13 18:07:45 +02:00
2019-05-19 23:33:34 +02:00
/* tssDesc.limitLow = limit & 0xffff; */
/* tssDesc.size = (limit >> 16) & 0xf; */
2019-03-29 10:29:05 +01:00
2019-05-19 23:33:34 +02:00
/* tssDesc.base00 = base & 0xffff; */
/* tssDesc.base16 = (base >> 16) & 0xff; */
/* tssDesc.base24 = (base >> 24) & 0xff; */
/* tssDesc.base32 = (base >> 32) & 0xffffffff; */
/* tssDesc.reserved = 0; */
2019-03-29 10:29:05 +01:00
2019-05-19 23:33:34 +02:00
/* tssDesc.access = 0x01 | 0x08 | 0x10 | 0x80; */
2019-05-13 18:07:45 +02:00
2019-05-19 23:33:34 +02:00
/* memmove(&gdtEntries[index], &tssDesc, sizeof(TssDescriptor_t)); */
/* } */
2019-05-13 18:07:45 +02:00
2019-03-29 10:29:05 +01:00
2019-05-19 23:33:34 +02:00
void MmInitGdt(void)
{
2019-05-20 20:28:18 +02:00
MmStoreGdt();
GdtEntry_t *gdt = (GdtEntry_t *)(gdtPtr.base);
extern ulong GDT64;
DebugLog("GDT ADDR: %p\n",
gdt
);
gdt++;
DebugLog("GDT : \n"
"lowLimit : %#016hx\n"
"lowBase : %#016hx\n"
"middleBase: %#016hx\n"
"access : %#016hx\n"
"flags : %#016hx\n"
"highBase : %#016hx\n",
gdt->lowLimit,
gdt->lowBase,
gdt->middleBase,
gdt->access,
gdt->flags,
gdt->highBase
);
/* DebugLog("GDT : \n" */
/* "lowLimit : %#016hx\n" */
/* "lowBase : %#016hx\n" */
/* "middleBase: %#016hx\n" */
/* "access : %#016hx\n" */
/* "flags : %#016hx\n" */
/* "highBase : %#016hx\n", */
/* gdt->lowLimit, */
/* gdt->lowBase, */
/* gdt->middleBase, */
/* gdt->access, */
/* gdt->flags, */
/* gdt->highBase */
/* ); */
2019-03-29 10:29:05 +01:00
2019-05-19 23:33:34 +02:00
MmLoadGdt();
2019-03-29 10:29:05 +01:00
}