From 5376e73c0def819688d611aa16ced335b70c4f71 Mon Sep 17 00:00:00 2001 From: Pawel Wieczorkiewicz Date: Mon, 13 Nov 2023 18:07:03 +0100 Subject: [PATCH] arch,pt: issue debug vmap/vunmap prints outside of CS Signed-off-by: Pawel Wieczorkiewicz --- arch/x86/pagetables.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/arch/x86/pagetables.c b/arch/x86/pagetables.c index a66afee4..3c0bd2b9 100644 --- a/arch/x86/pagetables.c +++ b/arch/x86/pagetables.c @@ -282,8 +282,6 @@ static void *_vmap(cr3_t *cr3_ptr, void *va, mfn_t mfn, unsigned int order, if ((_ul(va) & ~PAGE_ORDER_TO_MASK(order)) || !is_canon_va(va)) return va ? NULL : MAP_FAILED; - dprintk("%s: va: 0x%p mfn: 0x%lx (order: %u)\n", __func__, va, mfn, order); - #if defined(__x86_64__) l3t_mfn = get_pgentry_mfn(get_cr3_mfn(cr3_ptr), l4_table_index(va), l4_flags); #else @@ -326,6 +324,7 @@ void *vmap_kern(void *va, mfn_t mfn, unsigned int order, unsigned long l3_flags, unsigned long l2_flags, unsigned long l1_flags) { unsigned long _va = _ul(va) & PAGE_ORDER_TO_MASK(order); + dprintk("%s: va: 0x%p mfn: 0x%lx (order: %u)\n", __func__, va, mfn, order); spin_lock(&vmap_lock); va = _vmap(&cr3, _ptr(_va), mfn, order, l4_flags, l3_flags, l2_flags, l1_flags); spin_unlock(&vmap_lock); @@ -339,6 +338,7 @@ void *vmap_user(void *va, mfn_t mfn, unsigned int order, unsigned long l3_flags, unsigned long l2_flags, unsigned long l1_flags) { unsigned long _va = _ul(va) & PAGE_ORDER_TO_MASK(order); + dprintk("%s: va: 0x%p mfn: 0x%lx (order: %u)\n", __func__, va, mfn, order); spin_lock(&vmap_lock); va = _vmap(&user_cr3, _ptr(_va), mfn, order, l4_flags, l3_flags, l2_flags, l1_flags); spin_unlock(&vmap_lock); @@ -374,8 +374,6 @@ static int _vunmap(cr3_t *cr3_ptr, void *va, mfn_t *mfn, unsigned int *order) { if (mfn_invalid(cr3_ptr->mfn)) return -EINVAL; - dprintk("%s: va: 0x%p (cr3: 0x%p)\n", __func__, va, cr3_ptr); - tab = tmp_map_mfn(cr3_ptr->mfn); #if defined(__x86_64__) pml4_t *l4e = l4_table_entry((pml4_t *) tab, va); @@ -431,6 +429,7 @@ static int _vunmap(cr3_t *cr3_ptr, void *va, mfn_t *mfn, unsigned int *order) { int vunmap_kern(void *va, mfn_t *mfn, unsigned int *order) { int err; + dprintk("%s: va: 0x%p (cr3: 0x%p)\n", __func__, va, &cr3); spin_lock(&vmap_lock); err = _vunmap(&cr3, va, mfn, order); spin_unlock(&vmap_lock); @@ -440,6 +439,7 @@ int vunmap_kern(void *va, mfn_t *mfn, unsigned int *order) { int vunmap_user(void *va, mfn_t *mfn, unsigned int *order) { int err; + dprintk("%s: va: 0x%p (cr3: 0x%p)\n", __func__, va, &cr3); spin_lock(&vmap_lock); err = _vunmap(&user_cr3, va, mfn, order); spin_unlock(&vmap_lock);