Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/x86/x86 KNF a little, remove some stupid comments, ...
details: https://anonhg.NetBSD.org/src/rev/c3485b497915
branches: trunk
changeset: 816351:c3485b497915
user: maxv <maxv%NetBSD.org@localhost>
date: Fri Jul 01 12:12:06 2016 +0000
description:
KNF a little, remove some stupid comments, and add some when needed.
diffstat:
sys/arch/x86/x86/pmap.c | 198 +++++++++++++++++++++--------------------------
1 files changed, 89 insertions(+), 109 deletions(-)
diffs (truncated from 484 to 300 lines):
diff -r 2dc32bd7aa05 -r c3485b497915 sys/arch/x86/x86/pmap.c
--- a/sys/arch/x86/x86/pmap.c Fri Jul 01 11:57:10 2016 +0000
+++ b/sys/arch/x86/x86/pmap.c Fri Jul 01 12:12:06 2016 +0000
@@ -1,11 +1,11 @@
-/* $NetBSD: pmap.c,v 1.203 2016/07/01 11:57:10 maxv Exp $ */
+/* $NetBSD: pmap.c,v 1.204 2016/07/01 12:12:06 maxv Exp $ */
/*-
- * Copyright (c) 2008, 2010 The NetBSD Foundation, Inc.
+ * Copyright (c) 2008, 2010, 2016 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
- * by Andrew Doran.
+ * by Andrew Doran, and by Maxime Villard.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
@@ -171,7 +171,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.203 2016/07/01 11:57:10 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.204 2016/07/01 12:12:06 maxv Exp $");
#include "opt_user_ldt.h"
#include "opt_lockdebug.h"
@@ -366,7 +366,7 @@
static bool cpu_pat_enabled __read_mostly = false;
/*
- * global data structures
+ * Global data structures
*/
static struct pmap kernel_pmap_store; /* the kernel's pmap (proc0) */
@@ -388,7 +388,7 @@
* pmap_largepages: if our processor supports PG_PS and we are
* using it, this is set to true.
*/
-int pmap_largepages __read_mostly;
+int pmap_largepages __read_mostly = 0;
/*
* i386 physical memory comes in a big contig chunk with a small
@@ -466,48 +466,41 @@
}
/*
- * other data structures
+ * Other data structures
*/
-static pt_entry_t protection_codes[8] __read_mostly; /* maps MI prot to i386
- prot code */
+static pt_entry_t protection_codes[8] __read_mostly;
+
static bool pmap_initialized __read_mostly = false; /* pmap_init done yet? */
/*
- * the following two vaddr_t's are used during system startup
- * to keep track of how much of the kernel's VM space we have used.
- * once the system is started, the management of the remaining kernel
- * VM space is turned over to the kernel_map vm_map.
+ * The following two vaddr_t's are used during system startup to keep track of
+ * how much of the kernel's VM space we have used. Once the system is started,
+ * the management of the remaining kernel VM space is turned over to the
+ * kernel_map vm_map.
*/
-
static vaddr_t virtual_avail __read_mostly; /* VA of first free KVA */
static vaddr_t virtual_end __read_mostly; /* VA of last free KVA */
/*
* pool that pmap structures are allocated from
*/
-
static struct pool_cache pmap_cache;
/*
* pv_entry cache
*/
-
static struct pool_cache pmap_pv_cache;
#ifdef __HAVE_DIRECT_MAP
-
extern phys_ram_seg_t mem_clusters[];
extern int mem_cluster_cnt;
-
#else
-
/*
- * MULTIPROCESSOR: special VA's/ PTE's are actually allocated inside a
- * maxcpus*NPTECL array of PTE's, to avoid cache line thrashing
- * due to false sharing.
+ * MULTIPROCESSOR: special VAs and PTEs are actually allocated inside a
+ * (maxcpus * NPTECL) array of PTE, to avoid cache line thrashing due to
+ * false sharing.
*/
-
#ifdef MULTIPROCESSOR
#define PTESLEW(pte, id) ((pte)+(id)*NPTECL)
#define VASLEW(va,id) ((va)+(id)*NPTECL*PAGE_SIZE)
@@ -517,7 +510,7 @@
#endif
/*
- * special VAs and the PTEs that map them
+ * Special VAs and the PTEs that map them
*/
static pt_entry_t *csrc_pte, *cdst_pte, *zero_pte, *ptp_pte, *early_zero_pte;
static char *csrcp, *cdstp, *zerop, *ptpp;
@@ -546,7 +539,7 @@
};
#endif /* PAE */
-extern vaddr_t idt_vaddr; /* we allocate IDT early */
+extern vaddr_t idt_vaddr;
extern paddr_t idt_paddr;
extern int end;
@@ -556,38 +549,32 @@
extern vaddr_t pentium_idt_vaddr;
#endif
-
/*
- * local prototypes
+ * Local prototypes
*/
#ifdef __HAVE_DIRECT_MAP
static void pmap_init_directmap(struct pmap *);
#endif
-
#ifndef XEN
static void pmap_remap_largepages(void);
#endif
-static struct vm_page *pmap_get_ptp(struct pmap *, vaddr_t,
- pd_entry_t * const *);
-static struct vm_page *pmap_find_ptp(struct pmap *, vaddr_t, paddr_t, int);
-static void pmap_freepage(struct pmap *, struct vm_page *, int);
-static void pmap_free_ptp(struct pmap *, struct vm_page *,
- vaddr_t, pt_entry_t *,
- pd_entry_t * const *);
-static bool pmap_remove_pte(struct pmap *, struct vm_page *,
- pt_entry_t *, vaddr_t,
- struct pv_entry **);
-static void pmap_remove_ptes(struct pmap *, struct vm_page *,
- vaddr_t, vaddr_t, vaddr_t,
- struct pv_entry **);
-
-static bool pmap_get_physpage(vaddr_t, int, paddr_t *);
-static void pmap_alloc_level(pd_entry_t * const *, vaddr_t, int,
- long *);
-
-static bool pmap_reactivate(struct pmap *);
+static struct vm_page *pmap_get_ptp(struct pmap *, vaddr_t,
+ pd_entry_t * const *);
+static struct vm_page *pmap_find_ptp(struct pmap *, vaddr_t, paddr_t, int);
+static void pmap_freepage(struct pmap *, struct vm_page *, int);
+static void pmap_free_ptp(struct pmap *, struct vm_page *, vaddr_t,
+ pt_entry_t *, pd_entry_t * const *);
+static bool pmap_remove_pte(struct pmap *, struct vm_page *, pt_entry_t *,
+ vaddr_t, struct pv_entry **);
+static void pmap_remove_ptes(struct pmap *, struct vm_page *, vaddr_t, vaddr_t,
+ vaddr_t, struct pv_entry **);
+
+static bool pmap_get_physpage(vaddr_t, int, paddr_t *);
+static void pmap_alloc_level(pd_entry_t * const *, vaddr_t, int, long *);
+
+static bool pmap_reactivate(struct pmap *);
/*
* p m a p h e l p e r f u n c t i o n s
@@ -1008,7 +995,11 @@
npte |= pmap_pat_flags(flags);
opte = pmap_pte_testset(pte, npte); /* zap! */
#if defined(DIAGNOSTIC)
- /* XXX For now... */
+ /*
+ * XXX: make sure we are not dealing with a large page, since the only
+ * large pages created are for the kernel image, and they should never
+ * be kentered.
+ */
if (opte & PG_PS)
panic("%s: PG_PS", __func__);
#endif
@@ -1065,7 +1056,6 @@
} else {
tlbflush();
}
-
}
void
@@ -1186,7 +1176,7 @@
* pmap_bootstrap_valloc: allocate a virtual address in the bootstrap area.
* This function is to be used before any VM system has been set up.
*
- * The va is taken from virtual_avail.
+ * The va is taken from virtual_avail.
*/
static vaddr_t
pmap_bootstrap_valloc(size_t npages)
@@ -1200,7 +1190,7 @@
* pmap_bootstrap_palloc: allocate a physical address in the bootstrap area.
* This function is to be used before any VM system has been set up.
*
- * The pa is taken from avail_start.
+ * The pa is taken from avail_start.
*/
static paddr_t
pmap_bootstrap_palloc(size_t npages)
@@ -1211,13 +1201,12 @@
}
/*
- * pmap_bootstrap: get the system in a state where it can run with VM
- * properly enabled (called before main()). the VM system is
- * fully init'd later...
+ * pmap_bootstrap: get the system in a state where it can run with VM properly
+ * enabled (called before main()). The VM system is fully init'd later.
*
- * => on i386, locore.s has already enabled the MMU by allocating
- * a PDP for the kernel, and nkpde PTP's for the kernel.
- * => kva_start is the first free virtual address in kernel space
+ * => on i386, locore.S has already enabled the MMU by allocating a PDP for the
+ * kernel, and nkpde PTP's for the kernel.
+ * => kva_start is the first free virtual address in kernel space.
*/
void
pmap_bootstrap(vaddr_t kva_start)
@@ -1233,40 +1222,36 @@
pmap_pg_nx = (cpu_feature[2] & CPUID_NOX ? PG_NX : 0);
/*
- * set up our local static global vars that keep track of the
- * usage of KVM before kernel_map is set up
+ * Set up our local static global vars that keep track of the usage of
+ * KVM before kernel_map is set up.
*/
-
virtual_avail = kva_start; /* first free KVA */
virtual_end = VM_MAX_KERNEL_ADDRESS; /* last KVA */
/*
- * set up protection_codes: we need to be able to convert from
- * a MI protection code (some combo of VM_PROT...) to something
- * we can jam into a i386 PTE.
+ * Set up protection_codes: we need to be able to convert from a MI
+ * protection code (some combo of VM_PROT...) to something we can jam
+ * into a x86 PTE.
*/
-
- protection_codes[VM_PROT_NONE] = pmap_pg_nx; /* --- */
- protection_codes[VM_PROT_EXECUTE] = PG_RO | PG_X; /* --x */
- protection_codes[VM_PROT_READ] = PG_RO | pmap_pg_nx; /* -r- */
- protection_codes[VM_PROT_READ|VM_PROT_EXECUTE] = PG_RO | PG_X;/* -rx */
- protection_codes[VM_PROT_WRITE] = PG_RW | pmap_pg_nx; /* w-- */
- protection_codes[VM_PROT_WRITE|VM_PROT_EXECUTE] = PG_RW | PG_X;/* w-x */
+ protection_codes[VM_PROT_NONE] = pmap_pg_nx;
+ protection_codes[VM_PROT_EXECUTE] = PG_RO | PG_X;
+ protection_codes[VM_PROT_READ] = PG_RO | pmap_pg_nx;
+ protection_codes[VM_PROT_READ|VM_PROT_EXECUTE] = PG_RO | PG_X;
+ protection_codes[VM_PROT_WRITE] = PG_RW | pmap_pg_nx;
+ protection_codes[VM_PROT_WRITE|VM_PROT_EXECUTE] = PG_RW | PG_X;
protection_codes[VM_PROT_WRITE|VM_PROT_READ] = PG_RW | pmap_pg_nx;
- /* wr- */
- protection_codes[VM_PROT_ALL] = PG_RW | PG_X; /* wrx */
+ protection_codes[VM_PROT_ALL] = PG_RW | PG_X;
/*
- * now we init the kernel's pmap
+ * Now we init the kernel's pmap.
+ *
+ * The kernel pmap's pm_obj is not used for much. However, in user pmaps
+ * the pm_obj contains the list of active PTPs.
*
- * the kernel pmap's pm_obj is not used for much. however, in
- * user pmaps the pm_obj contains the list of active PTPs.
- * the pm_obj currently does not have a pager. it might be possible
- * to add a pager that would allow a process to read-only mmap its
- * own page tables (fast user level vtophys?). this may or may not
- * be useful.
+ * The pm_obj currently does not have a pager. It might be possible to
+ * add a pager that would allow a process to read-only mmap its own page
+ * tables (fast user-level vtophys?). This may or may not be useful.
*/
-
kpm = pmap_kernel();
for (i = 0; i < PTP_LEVELS - 1; i++) {
mutex_init(&kpm->pm_obj_lock[i], MUTEX_DEFAULT, IPL_NONE);
@@ -1359,8 +1344,8 @@
}
/*
- * now we allocate the "special" VAs which are used for tmp mappings
Home |
Main Index |
Thread Index |
Old Index