Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch Localify.



details:   https://anonhg.NetBSD.org/src/rev/d1aedcfa0a11
branches:  trunk
changeset: 817449:d1aedcfa0a11
user:      maxv <maxv%NetBSD.org@localhost>
date:      Sat Aug 20 16:05:48 2016 +0000

description:
Localify.

diffstat:

 sys/arch/amd64/amd64/gdt.c  |  22 +++++++++----------
 sys/arch/i386/i386/gdt.c    |  50 +++++++++++++++++++++-----------------------
 sys/arch/i386/include/gdt.h |   4 +--
 3 files changed, 35 insertions(+), 41 deletions(-)

diffs (222 lines):

diff -r 057e98221012 -r d1aedcfa0a11 sys/arch/amd64/amd64/gdt.c
--- a/sys/arch/amd64/amd64/gdt.c        Sat Aug 20 15:50:50 2016 +0000
+++ b/sys/arch/amd64/amd64/gdt.c        Sat Aug 20 16:05:48 2016 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: gdt.c,v 1.26 2015/11/22 13:41:24 maxv Exp $    */
+/*     $NetBSD: gdt.c,v 1.27 2016/08/20 16:05:48 maxv Exp $    */
 
 /*-
  * Copyright (c) 1996, 1997, 2009 The NetBSD Foundation, Inc.
@@ -37,7 +37,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: gdt.c,v 1.26 2015/11/22 13:41:24 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: gdt.c,v 1.27 2016/08/20 16:05:48 maxv Exp $");
 
 #include "opt_multiprocessor.h"
 #include "opt_xen.h"
@@ -64,9 +64,9 @@
 int gdt_free;          /* next free slot; terminated with GNULL_SEL */
 
 void gdt_init(void);
-void gdt_grow(void);
-int gdt_get_slot(void);
-void gdt_put_slot(int);
+static void gdt_grow(void);
+static int gdt_get_slot(void);
+static void gdt_put_slot(int);
 
 void
 update_descriptor(void *tp, void *ep)
@@ -88,8 +88,7 @@
 }
 
 void
-set_sys_gdt(int slot, void *base, size_t limit,
-           int type, int dpl, int gran)
+set_sys_gdt(int slot, void *base, size_t limit, int type, int dpl, int gran)
 {
        union {
                struct sys_segment_descriptor sd;
@@ -208,11 +207,10 @@
 }
 #endif
 
-
 /*
  * Grow or shrink the GDT.
  */
-void
+static void
 gdt_grow(void)
 {
        size_t old_len, new_len;
@@ -223,7 +221,7 @@
        gdt_size <<= 1;
        new_len = old_len << 1;
        gdt_dynavail =
-           (gdt_size - DYNSEL_START) / sizeof (struct sys_segment_descriptor);
+           (gdt_size - DYNSEL_START) / sizeof(struct sys_segment_descriptor);
 
        for (va = (vaddr_t)gdtstore + old_len; va < (vaddr_t)gdtstore + new_len;
            va += PAGE_SIZE) {
@@ -245,7 +243,7 @@
  * 3) As a last resort, we increase the size of the GDT, and sweep through
  *    the new slots.
  */
-int
+static int
 gdt_get_slot(void)
 {
        int slot;
@@ -280,7 +278,7 @@
 /*
  * Deallocate a GDT slot, putting it on the free list.
  */
-void
+static void
 gdt_put_slot(int slot)
 {
        struct sys_segment_descriptor *gdt;
diff -r 057e98221012 -r d1aedcfa0a11 sys/arch/i386/i386/gdt.c
--- a/sys/arch/i386/i386/gdt.c  Sat Aug 20 15:50:50 2016 +0000
+++ b/sys/arch/i386/i386/gdt.c  Sat Aug 20 16:05:48 2016 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: gdt.c,v 1.53 2012/02/24 08:06:07 cherry Exp $  */
+/*     $NetBSD: gdt.c,v 1.54 2016/08/20 16:05:48 maxv Exp $    */
 
 /*-
  * Copyright (c) 1996, 1997, 2009 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: gdt.c,v 1.53 2012/02/24 08:06:07 cherry Exp $");
+__KERNEL_RCSID(0, "$NetBSD: gdt.c,v 1.54 2016/08/20 16:05:48 maxv Exp $");
 
 #include "opt_multiprocessor.h"
 #include "opt_xen.h"
@@ -61,9 +61,9 @@
 static int ldt_max = 1000;/* max number of LDTs */
 
 void gdt_init(void);
-void gdt_grow(int);
-int gdt_get_slot1(int);
-void gdt_put_slot1(int, int);
+static void gdt_grow(int);
+static int gdt_get_slot1(int);
+static void gdt_put_slot1(int, int);
 
 void
 update_descriptor(union descriptor *table, union descriptor *entry)
@@ -82,8 +82,8 @@
 }
 
 void
-setgdt(int sel, const void *base, size_t limit,
-    int type, int dpl, int def32, int gran)
+setgdt(int sel, const void *base, size_t limit, int type, int dpl, int def32,
+    int gran)
 {
        struct segment_descriptor *sd = &gdt[sel].sd;
        CPU_INFO_ITERATOR cii;
@@ -201,23 +201,21 @@
        pt_entry_t *ptp;
        int f;
 
-       for (va = (vaddr_t)ci->ci_gdt, f = 0;
-            va < (vaddr_t)ci->ci_gdt + len;
-            va += PAGE_SIZE, f++) {
+       for (va = (vaddr_t)ci->ci_gdt, f = 0; va < (vaddr_t)ci->ci_gdt + len;
+           va += PAGE_SIZE, f++) {
                KASSERT(va >= VM_MIN_KERNEL_ADDRESS);
                ptp = kvtopte(va);
                frames[f] = *ptp >> PAGE_SHIFT;
-               { 
-                  /* 
-                   * pmap_pte_clearbits(ptp, PG_RW);
-                   * but without spl(), since %fs is not setup
-                   * properly yet, ie; curcpu() won't work at this
-                   * point and spl() will break.
-                   */
-                       if (HYPERVISOR_update_va_mapping((vaddr_t)va,
-                               *ptp & ~PG_RW, UVMF_INVLPG) < 0) {
-                               panic("%s page RO update failed.\n", __func__);
-                       }
+
+               /* 
+                * pmap_pte_clearbits(ptp, PG_RW);
+                * but without spl(), since %fs is not setup
+                * properly yet, ie; curcpu() won't work at this
+                * point and spl() will break.
+                */
+               if (HYPERVISOR_update_va_mapping((vaddr_t)va,
+                       *ptp & ~PG_RW, UVMF_INVLPG) < 0) {
+                       panic("%s page RO update failed.\n", __func__);
                }
        }
 
@@ -274,7 +272,7 @@
                                        uvm_wait("gdt_grow");
                                }
                                pmap_kenter_pa(va, VM_PAGE_TO_PHYS(pg),
-                                              VM_PROT_READ | VM_PROT_WRITE, 0);
+                                   VM_PROT_READ | VM_PROT_WRITE, 0);
                        }
                }
                return;
@@ -306,7 +304,7 @@
  *    the new slots.
  */
 
-int
+static int
 gdt_get_slot(void)
 {
 
@@ -315,7 +313,7 @@
        return gdt_get_slot1(0);
 }
 
-int
+static int
 gdt_get_slot1(int which)
 {
        int slot;
@@ -345,7 +343,7 @@
 /*
  * Deallocate a GDT slot, putting it on the free list.
  */
-void
+static void
 gdt_put_slot(int slot)
 {
 
@@ -354,7 +352,7 @@
        gdt_put_slot1(slot, 0);
 }
 
-void
+static void
 gdt_put_slot1(int slot, int which)
 {
        union descriptor d;
diff -r 057e98221012 -r d1aedcfa0a11 sys/arch/i386/include/gdt.h
--- a/sys/arch/i386/include/gdt.h       Sat Aug 20 15:50:50 2016 +0000
+++ b/sys/arch/i386/include/gdt.h       Sat Aug 20 16:05:48 2016 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: gdt.h,v 1.13 2008/04/28 20:23:24 martin Exp $  */
+/*     $NetBSD: gdt.h,v 1.14 2016/08/20 16:05:48 maxv Exp $    */
 
 /*-
  * Copyright (c) 1996, 1997 The NetBSD Foundation, Inc.
@@ -37,8 +37,6 @@
 void gdt_init(void);
 void gdt_init_cpu(struct cpu_info *);
 void gdt_reload_cpu(struct cpu_info *);
-int gdt_get_slot(void);
-void gdt_put_slot(int);
 void gdt_alloc_cpu(struct cpu_info *);
 int tss_alloc(const struct i386tss *);
 void tss_free(int);



Home | Main Index | Thread Index | Old Index