2024-07-07 09:44:51 +00:00
|
|
|
;; File: mm.inc
|
2024-07-07 13:29:41 +00:00
|
|
|
;; StupidOS Memory Manager
|
2024-07-08 17:10:37 +00:00
|
|
|
;;
|
|
|
|
;; About: Memory Layout
|
|
|
|
;;
|
|
|
|
;; > Virtual
|
|
|
|
;; > 0xFFFFFFFF +---------------+
|
|
|
|
;; > | |
|
|
|
|
;; > | Device Memory |
|
|
|
|
;; > | |
|
|
|
|
;; > +---------------+
|
|
|
|
;; > | |
|
|
|
|
;; > | Kernel Heap |
|
|
|
|
;; > | |
|
|
|
|
;; > KERN_END +---------------+
|
|
|
|
;; > | |
|
|
|
|
;; > | Stupid Kernel |
|
|
|
|
;; > | |
|
|
|
|
;; > 0xC0100000 +---------------+
|
|
|
|
;; > | I/O Space and |
|
|
|
|
;; > | phys memory |
|
|
|
|
;; > | Lower than 1M | kernel mode only
|
|
|
|
;; > 0xC0000000 +---------------+
|
|
|
|
;; > | | user mode
|
|
|
|
;; > | userspace |
|
|
|
|
;; > | |
|
|
|
|
;; > 0x00000000 +---------------+
|
|
|
|
;;
|
2024-07-07 13:29:41 +00:00
|
|
|
|
2024-07-06 13:19:35 +00:00
|
|
|
include "pmm.inc"
|
2024-07-08 17:10:37 +00:00
|
|
|
include "../sys/mmu.inc"
|
2024-02-04 19:18:52 +00:00
|
|
|
|
2024-07-08 17:10:37 +00:00
|
|
|
;; Macro: KV2P
|
|
|
|
;; Convert virtual address to physical
|
2024-07-08 16:48:31 +00:00
|
|
|
macro KV2P reg {
|
|
|
|
sub reg, KERNEL_VIRT_BASE
|
|
|
|
}
|
|
|
|
|
2024-07-08 17:10:37 +00:00
|
|
|
;; Macro: KP2V
|
|
|
|
macro KP2V reg {
|
|
|
|
add reg, KERNEL_VIRT_BASE
|
|
|
|
}
|
|
|
|
|
|
|
|
mm_kmap:
|
|
|
|
ret
|
|
|
|
|
|
|
|
;; Function: mm_init
|
2024-02-04 19:18:52 +00:00
|
|
|
mm_init:
|
2024-07-07 09:24:51 +00:00
|
|
|
mov esi, szMsgMmInit
|
|
|
|
call klog
|
|
|
|
|
|
|
|
call pmm_alloc_page
|
|
|
|
mov [pKernelPgDir], eax
|
|
|
|
|
2024-07-07 13:29:41 +00:00
|
|
|
; clear page dir
|
|
|
|
mov ecx, 4096
|
|
|
|
xor al, al
|
|
|
|
mov edi, [pKernelPgDir]
|
|
|
|
rep stosb
|
|
|
|
|
|
|
|
;; Map kernel and kmemory
|
|
|
|
call pmm_alloc_page
|
2024-07-08 16:48:31 +00:00
|
|
|
xor esi, esi
|
|
|
|
xor ecx, ecx
|
2024-07-07 13:29:41 +00:00
|
|
|
mov edi, eax
|
2024-07-08 16:48:31 +00:00
|
|
|
@@:
|
|
|
|
mov edx, esi
|
2024-07-08 17:10:37 +00:00
|
|
|
or edx, (PTE_P or PTE_W)
|
2024-07-08 16:48:31 +00:00
|
|
|
mov [edi], edx
|
|
|
|
add edi, 4
|
|
|
|
add esi, 4096
|
|
|
|
inc ecx
|
|
|
|
cmp ecx, 1024
|
|
|
|
jb @b
|
|
|
|
|
2024-07-08 17:10:37 +00:00
|
|
|
or eax, (PDE_P or PDE_W)
|
2024-07-08 16:48:31 +00:00
|
|
|
mov edx, [pKernelPgDir]
|
|
|
|
add edx, (768 * 4)
|
|
|
|
KV2P eax
|
|
|
|
mov [edx], eax
|
2024-07-07 09:44:51 +00:00
|
|
|
|
|
|
|
;; Map free memory
|
|
|
|
|
2024-07-08 16:48:31 +00:00
|
|
|
mov eax, [pKernelPgDir]
|
|
|
|
KV2P eax
|
|
|
|
mov cr3, eax
|
|
|
|
|
|
|
|
push eax
|
|
|
|
mov esi, szMsgMmKernelPgDir
|
|
|
|
call klog
|
2024-07-07 09:44:51 +00:00
|
|
|
|
|
|
|
ret
|
|
|
|
|
|
|
|
mm_wallk_pagedir:
|
2024-04-28 06:41:36 +00:00
|
|
|
ret
|
2024-07-07 09:24:51 +00:00
|
|
|
|
|
|
|
szMsgMmInit db "MM: initialize", 0
|
2024-07-08 16:48:31 +00:00
|
|
|
szMsgMmKernelPgDir db "MM: Kernel page dir at %x phys", 0
|
|
|
|
pKernelPgDir dd 0
|