Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/aarch64 separate struct vm_page_md into vm_page_md ...
details: https://anonhg.NetBSD.org/src/rev/7a56f1d290b6
branches: trunk
changeset: 1007018:7a56f1d290b6
user: ryo <ryo%NetBSD.org@localhost>
date: Mon Feb 03 13:35:44 2020 +0000
description:
separate struct vm_page_md into vm_page_md and pmap_page
for preparation pmap_pv(9)
diffstat:
sys/arch/aarch64/aarch64/pmap.c | 301 +++++++++++++++++++++------------------
sys/arch/aarch64/include/pmap.h | 29 ++-
2 files changed, 180 insertions(+), 150 deletions(-)
diffs (truncated from 744 to 300 lines):
diff -r ca5884a75e50 -r 7a56f1d290b6 sys/arch/aarch64/aarch64/pmap.c
--- a/sys/arch/aarch64/aarch64/pmap.c Mon Feb 03 13:28:11 2020 +0000
+++ b/sys/arch/aarch64/aarch64/pmap.c Mon Feb 03 13:35:44 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pmap.c,v 1.61 2020/01/09 01:38:34 ryo Exp $ */
+/* $NetBSD: pmap.c,v 1.62 2020/02/03 13:35:44 ryo Exp $ */
/*
* Copyright (c) 2017 Ryo Shimizu <ryo%nerv.org@localhost>
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.61 2020/01/09 01:38:34 ryo Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.62 2020/02/03 13:35:44 ryo Exp $");
#include "opt_arm_debug.h"
#include "opt_ddb.h"
@@ -183,6 +183,8 @@
cpu_icache_sync_range((va), PAGE_SIZE); \
} while (0/*CONSTCOND*/)
+#define VM_PAGE_TO_PP(pg) (&(pg)->mdpage.mdpg_pp)
+
struct pv_entry {
TAILQ_ENTRY(pv_entry) pv_link;
struct pmap *pv_pmap;
@@ -217,17 +219,17 @@
static inline void
-pmap_pv_lock(struct vm_page_md *md)
+pmap_pv_lock(struct pmap_page *pp)
{
- mutex_enter(&md->mdpg_pvlock);
+ mutex_enter(&pp->pp_pvlock);
}
static inline void
-pmap_pv_unlock(struct vm_page_md *md)
+pmap_pv_unlock(struct pmap_page *pp)
{
- mutex_exit(&md->mdpg_pvlock);
+ mutex_exit(&pp->pp_pvlock);
}
@@ -243,6 +245,18 @@
mutex_exit(&pm->pm_lock);
}
+static inline struct pmap_page *
+phys_to_pp(paddr_t pa)
+{
+ struct vm_page *pg;
+
+ pg = PHYS_TO_VM_PAGE(pa);
+ if (pg != NULL)
+ return VM_PAGE_TO_PP(pg);
+
+ return NULL;
+}
+
#define IN_RANGE(va,sta,end) (((sta) <= (va)) && ((va) < (end)))
#define IN_KSEG_ADDR(va) \
@@ -512,7 +526,7 @@
0, 0, 0, "pvpl", NULL, IPL_VM, _pmap_pv_ctor, NULL, NULL);
/*
- * initialize vm_page_md:mdpg_pvlock at this time.
+ * initialize mutex in vm_page_md at this time.
* When LOCKDEBUG, mutex_init() calls km_alloc,
* but VM_MDPAGE_INIT() is called before initialized kmem_vm_arena.
*/
@@ -524,7 +538,7 @@
pfn++) {
pg = PHYS_TO_VM_PAGE(ptoa(pfn));
md = VM_PAGE_TO_MD(pg);
- mutex_init(&md->mdpg_pvlock, MUTEX_SPIN, IPL_VM);
+ mutex_init(&md->mdpg_pp.pp_pvlock, MUTEX_SPIN, IPL_VM);
}
}
}
@@ -994,22 +1008,19 @@
}
static struct pv_entry *
-_pmap_remove_pv(struct vm_page *pg, struct pmap *pm, vaddr_t va, pt_entry_t pte)
+_pmap_remove_pv(struct pmap_page *pp, struct pmap *pm, vaddr_t va, pt_entry_t pte)
{
- struct vm_page_md *md;
struct pv_entry *pv;
UVMHIST_FUNC(__func__);
UVMHIST_CALLED(pmaphist);
- UVMHIST_LOG(pmaphist, "pg=%p, pm=%p, va=%llx, pte=%llx",
- pg, pm, va, pte);
-
- md = VM_PAGE_TO_MD(pg);
-
- TAILQ_FOREACH(pv, &md->mdpg_pvhead, pv_link) {
+ UVMHIST_LOG(pmaphist, "pp=%p, pm=%p, va=%llx, pte=%llx",
+ pp, pm, va, pte);
+
+ TAILQ_FOREACH(pv, &pp->pp_pvhead, pv_link) {
if ((pm == pv->pv_pmap) && (va == pv->pv_va)) {
- TAILQ_REMOVE(&md->mdpg_pvhead, pv, pv_link);
+ TAILQ_REMOVE(&pp->pp_pvhead, pv, pv_link);
PMAP_COUNT(pv_remove);
break;
}
@@ -1061,18 +1072,18 @@
}
static void
-pv_dump(struct vm_page_md *md, void (*pr)(const char *, ...) __printflike(1, 2))
+pv_dump(struct pmap_page *pp, void (*pr)(const char *, ...) __printflike(1, 2))
{
struct pv_entry *pv;
int i;
i = 0;
- pr("md=%p\n", md);
- pr(" md->mdpg_flags=%08x %s\n", md->mdpg_flags,
- str_vmflags(md->mdpg_flags));
-
- TAILQ_FOREACH(pv, &md->mdpg_pvhead, pv_link) {
+ pr("pp=%p\n", pp);
+ pr(" pp->pp_flags=%08x %s\n", pp->pp_flags,
+ str_vmflags(pp->pp_flags));
+
+ TAILQ_FOREACH(pv, &pp->pp_pvhead, pv_link) {
pr(" pv[%d] pv=%p\n",
i, pv);
pr(" pv[%d].pv_pmap = %p (asid=%d)\n",
@@ -1089,22 +1100,19 @@
#endif /* PMAP_PV_DEBUG & DDB */
static int
-_pmap_enter_pv(struct vm_page *pg, struct pmap *pm, struct pv_entry **pvp,
+_pmap_enter_pv(struct pmap_page *pp, struct pmap *pm, struct pv_entry **pvp,
vaddr_t va, pt_entry_t *ptep, paddr_t pa, u_int flags)
{
- struct vm_page_md *md;
struct pv_entry *pv;
UVMHIST_FUNC(__func__);
UVMHIST_CALLED(pmaphist);
- UVMHIST_LOG(pmaphist, "pg=%p, pm=%p, va=%llx, pa=%llx", pg, pm, va, pa);
+ UVMHIST_LOG(pmaphist, "pp=%p, pm=%p, va=%llx, pa=%llx", pp, pm, va, pa);
UVMHIST_LOG(pmaphist, "ptep=%p, flags=%08x", ptep, flags, 0, 0);
- md = VM_PAGE_TO_MD(pg);
-
/* pv is already registered? */
- TAILQ_FOREACH(pv, &md->mdpg_pvhead, pv_link) {
+ TAILQ_FOREACH(pv, &pp->pp_pvhead, pv_link) {
if ((pm == pv->pv_pmap) && (va == pv->pv_va)) {
break;
}
@@ -1125,14 +1133,14 @@
pv->pv_pa = pa;
pv->pv_ptep = ptep;
- TAILQ_INSERT_HEAD(&md->mdpg_pvhead, pv, pv_link);
+ TAILQ_INSERT_HEAD(&pp->pp_pvhead, pv, pv_link);
PMAP_COUNT(pv_enter);
#ifdef PMAP_PV_DEBUG
- if (!TAILQ_EMPTY(&md->mdpg_pvhead)){
+ if (!TAILQ_EMPTY(&pp->pp_pvhead)){
printf("pv %p alias added va=%016lx -> pa=%016lx\n",
pv, va, pa);
- pv_dump(md, printf);
+ pv_dump(pp, printf);
}
#endif
}
@@ -1175,7 +1183,7 @@
}
static void
-_pmap_protect_pv(struct vm_page *pg, struct pv_entry *pv, vm_prot_t prot)
+_pmap_protect_pv(struct pmap_page *pp, struct pv_entry *pv, vm_prot_t prot)
{
pt_entry_t *ptep, pte;
vm_prot_t pteprot;
@@ -1185,10 +1193,10 @@
UVMHIST_FUNC(__func__);
UVMHIST_CALLED(pmaphist);
- UVMHIST_LOG(pmaphist, "pg=%p, pv=%p, prot=%08x", pg, pv, prot, 0);
+ UVMHIST_LOG(pmaphist, "pp=%p, pv=%p, prot=%08x", pp, pv, prot, 0);
/* get prot mask from referenced/modified */
- mdattr = VM_PAGE_TO_MD(pg)->mdpg_flags &
+ mdattr = pp->pp_flags &
(VM_PROT_READ | VM_PROT_WRITE);
pm_lock(pv->pv_pmap);
@@ -1253,6 +1261,7 @@
pt_entry_t opte;
#endif
struct vm_page *pg;
+ struct pmap_page *pp;
paddr_t pa;
uint32_t mdattr;
bool executable;
@@ -1271,16 +1280,20 @@
pa = lxpde_pa(pte);
pg = PHYS_TO_VM_PAGE(pa);
-
if (pg != NULL) {
+ pp = VM_PAGE_TO_PP(pg);
+ PMAP_COUNT(protect_managed);
+ } else {
+ pp = NULL;
+ PMAP_COUNT(protect_unmanaged);
+ }
+
+ if (pp != NULL) {
/* get prot mask from referenced/modified */
- mdattr = VM_PAGE_TO_MD(pg)->mdpg_flags &
- (VM_PROT_READ | VM_PROT_WRITE);
- PMAP_COUNT(protect_managed);
+ mdattr = pp->pp_flags & (VM_PROT_READ | VM_PROT_WRITE);
} else {
/* unmanaged page */
mdattr = VM_PROT_ALL;
- PMAP_COUNT(protect_unmanaged);
}
#ifdef UVMHIST
@@ -1553,7 +1566,8 @@
_pmap_enter(struct pmap *pm, vaddr_t va, paddr_t pa, vm_prot_t prot,
u_int flags, bool kenter)
{
- struct vm_page *pg, *pgs[2], *pdppg, *pdppg0;
+ struct vm_page *pdppg, *pdppg0;
+ struct pmap_page *pp, *opp, *pps[2];
struct pv_entry *spv, *opv = NULL;
pd_entry_t pde;
pt_entry_t attr, pte, opte, *ptep;
@@ -1599,13 +1613,20 @@
}
#endif
- if (kenter)
- pg = NULL;
- else
- pg = PHYS_TO_VM_PAGE(pa);
-
- if (pg != NULL) {
- PMAP_COUNT(managed_mappings);
+ if (kenter) {
+ pp = NULL;
+ } else {
+ struct vm_page *pg = PHYS_TO_VM_PAGE(pa);
+ if (pg != NULL) {
+ pp = VM_PAGE_TO_PP(pg);
+ PMAP_COUNT(managed_mappings);
+ } else {
+ pp = NULL;
+ PMAP_COUNT(unmanaged_mappings);
+ }
+ }
+
+ if (pp != NULL) {
/*
* allocate pv in advance of pm_lock() to avoid locking myself.
* pool_cache_get() may call pmap_kenter() internally.
@@ -1613,7 +1634,6 @@
spv = pool_cache_get(&_pmap_pv_pool, PR_NOWAIT);
need_update_pv = true;
} else {
- PMAP_COUNT(unmanaged_mappings);
spv = NULL;
need_update_pv = false;
}
@@ -1708,13 +1728,12 @@
opte = atomic_swap_64(ptep, 0);
need_sync_icache = (prot & VM_PROT_EXECUTE);
- /* for lock ordering for pg and opg */
- pgs[0] = pg;
- pgs[1] = NULL;
+ /* for lock ordering for old page and new page */
+ pps[0] = pp;
+ pps[1] = NULL;
/* remap? */
if (l3pte_valid(opte)) {
- struct vm_page *opg;
Home |
Main Index |
Thread Index |
Old Index