aboutsummaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/amd64/amd64/pmap.c32
1 files changed, 32 insertions, 0 deletions
diff --git a/sys/arch/amd64/amd64/pmap.c b/sys/arch/amd64/amd64/pmap.c
index e95471b..9443727 100644
--- a/sys/arch/amd64/amd64/pmap.c
+++ b/sys/arch/amd64/amd64/pmap.c
@@ -255,6 +255,38 @@ pmap_modify_tbl(struct vm_ctx *ctx, struct vas vas, vaddr_t va, size_t val)
}
int
+pmap_set_cache(struct vm_ctx *ctx, struct vas vas, vaddr_t va, int type)
+{
+ uintptr_t *tbl;
+ int status;
+ size_t idx;
+
+ if ((status = pmap_get_tbl(ctx, vas, va, false, &tbl)) != 0) {
+ return status;
+ }
+
+ idx = pmap_get_level_index(1, va);
+
+ /* Set the policy based on the type */
+ switch (type) {
+ case VM_CACHE_UC:
+ tbl[idx] |= PTE_PCD;
+ tbl[idx] &= ~(PTE_PWT);
+ break;
+ case VM_CACHE_WT:
+ tbl[idx] &= ~(PTE_PCD);
+ tbl[idx] |= PTE_PWT;
+ break;
+ default:
+ /* Invalid type */
+ return 1;
+ }
+
+ pmap_flush(va);
+ return 0;
+}
+
+int
pmap_map(struct vm_ctx *ctx, struct vas vas, vaddr_t va, paddr_t pa,
vm_prot_t prot)
{