git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Restructure the interrupt vector distribution for better matching of their inherit...
[lunaix-os.git]
/
lunaix-os
/
includes
/
lunaix
/
mm
/
vmm.h
diff --git
a/lunaix-os/includes/lunaix/mm/vmm.h
b/lunaix-os/includes/lunaix/mm/vmm.h
index a0c455fdf4c765576c86faa7b4cbede8210cdd3d..3e124fc9923a12249f35b8267013876b4e3eb8fe 100644
(file)
--- a/
lunaix-os/includes/lunaix/mm/vmm.h
+++ b/
lunaix-os/includes/lunaix/mm/vmm.h
@@
-17,12
+17,12
@@
vmm_init();
*
* @return ptd_entry* 页目录的物理地址,随时可以加载进CR3
*/
*
* @return ptd_entry* 页目录的物理地址,随时可以加载进CR3
*/
-
ptd_t
*
+
x86_page_table
*
vmm_init_pd();
/**
* @brief 尝试建立一个映射关系。映射指定的物理页地址至虚拟页地址,如果指定的虚拟页地址已被占用
vmm_init_pd();
/**
* @brief 尝试建立一个映射关系。映射指定的物理页地址至虚拟页地址,如果指定的虚拟页地址已被占用
- * 则尝试寻找新的可用地址(
改
地址总是大于指定的地址)。
+ * 则尝试寻找新的可用地址(
该
地址总是大于指定的地址)。
*
* @param vpn 虚拟页地址
* @param pa 物理页地址
*
* @param vpn 虚拟页地址
* @param pa 物理页地址
@@
-67,6
+67,16
@@
vmm_alloc_page(void* va, pt_attr tattr);
int
vmm_alloc_pages(void* va, size_t sz, pt_attr tattr);
int
vmm_alloc_pages(void* va, size_t sz, pt_attr tattr);
+/**
+ * @brief 设置一个映射,如果映射已存在,则忽略。
+ *
+ * @param va
+ * @param pa
+ * @param attr
+ */
+void
+vmm_set_mapping(void* va, void* pa, pt_attr attr);
+
/**
* @brief 删除一个映射
*
/**
* @brief 删除一个映射
*