Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/cats Convert cats to the new world order, i.e. arm3...



details:   https://anonhg.NetBSD.org/src/rev/0cc6893cda90
branches:  trunk
changeset: 795149:0cc6893cda90
user:      skrll <skrll%NetBSD.org@localhost>
date:      Wed Apr 02 17:36:05 2014 +0000

description:
Convert cats to the new world order, i.e. arm32_{bootmem,kernel_vm}_init

diffstat:

 sys/arch/cats/cats/cats_machdep.c |  421 +++++--------------------------------
 sys/arch/cats/conf/files.cats     |    6 +-
 2 files changed, 70 insertions(+), 357 deletions(-)

diffs (truncated from 575 to 300 lines):

diff -r 4cd453fe76db -r 0cc6893cda90 sys/arch/cats/cats/cats_machdep.c
--- a/sys/arch/cats/cats/cats_machdep.c Wed Apr 02 17:19:49 2014 +0000
+++ b/sys/arch/cats/cats/cats_machdep.c Wed Apr 02 17:36:05 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cats_machdep.c,v 1.78 2014/04/02 11:36:50 matt Exp $   */
+/*     $NetBSD: cats_machdep.c,v 1.79 2014/04/02 17:36:05 skrll Exp $  */
 
 /*
  * Copyright (c) 1997,1998 Mark Brinicombe.
@@ -40,7 +40,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cats_machdep.c,v 1.78 2014/04/02 11:36:50 matt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cats_machdep.c,v 1.79 2014/04/02 17:36:05 skrll Exp $");
 
 #include "opt_ddb.h"
 #include "opt_modular.h"
@@ -74,6 +74,8 @@
 #include <arm/locore.h>
 #include <arm/undefined.h>
 #include <arm/arm32/machdep.h>
+
+#include <machine/pmap.h>
  
 #include <machine/cyclone_boot.h>
 #include <arm/footbridge/dc21285mem.h>
@@ -116,30 +118,11 @@
 char *boot_args = NULL;
 char *boot_file = NULL;
 
-vm_offset_t physical_start;
-vm_offset_t physical_freestart;
-vm_offset_t physical_freeend;
-vm_offset_t physical_end;
-u_int free_pages;
-vm_offset_t pagetables_start;
-
-vm_offset_t msgbufphys;
 
 #ifdef PMAP_DEBUG
 extern int pmap_debug_level;
 #endif
 
-#define KERNEL_PT_SYS          0       /* L2 table for mapping zero page */
-#define KERNEL_PT_KERNEL       1       /* L2 table for mapping kernel */
-#define        KERNEL_PT_KERNEL_NUM    2
-
-/* now this could move into something more generic */
-                                       /* L2 tables for mapping kernel VM */
-#define        KERNEL_PT_VMDATA        (KERNEL_PT_KERNEL + KERNEL_PT_KERNEL_NUM)
-#define        KERNEL_PT_VMDATA_NUM    4       /* 16MB kernel VM !*/
-#define NUM_KERNEL_PTS         (KERNEL_PT_VMDATA + KERNEL_PT_VMDATA_NUM)
-
-pv_addr_t kernel_pt_table[NUM_KERNEL_PTS];
 
 /* Prototypes */
 
@@ -190,88 +173,7 @@
 int comcnspeed = CONSPEED;
 int comcnmode = CONMODE;
 
-
-/*
- * void cpu_reboot(int howto, char *bootstr)
- *
- * Reboots the system
- *
- * Deal with any syncing, unmounting, dumping and shutdown hooks,
- * then reset the CPU.
- */
-
-void
-cpu_reboot(int howto, char *bootstr)
-{
-#ifdef DIAGNOSTIC
-       /* info */
-       printf("boot: howto=%08x curlwp=%p\n", howto, curlwp);
-#endif
-
-       /*
-        * If we are still cold then hit the air brakes
-        * and crash to earth fast
-        */
-       if (cold) {
-               doshutdownhooks();
-               pmf_system_shutdown(boothowto);
-               printf("The operating system has halted.\n");
-               printf("Please press any key to reboot.\n\n");
-               cngetc();
-               printf("rebooting...\n");
-               cpu_reset();
-               /*NOTREACHED*/
-       }
-
-       /* Disable console buffering */
-/*     cnpollc(1);*/
-
-       /*
-        * If RB_NOSYNC was not specified sync the discs.
-        * Note: Unless cold is set to 1 here, syslogd will die during the unmount.
-        * It looks like syslogd is getting woken up only to find that it cannot
-        * page part of the binary in as the filesystem has been unmounted.
-        */
-       if (!(howto & RB_NOSYNC))
-               bootsync();
-
-       /* Say NO to interrupts */
-       splhigh();
-
-       /* Do a dump if requested. */
-       if ((howto & (RB_DUMP | RB_HALT)) == RB_DUMP)
-               dumpsys();
-       
-       /* Run any shutdown hooks */
-       doshutdownhooks();
-
-       pmf_system_shutdown(boothowto);
-
-       /* Make sure IRQ's are disabled */
-       IRQdisable;
-
-       if (howto & RB_HALT) {
-               printf("The operating system has halted.\n");
-               printf("Please press any key to reboot.\n\n");
-               cngetc();
-       }
-
-       printf("rebooting...\n");
-       cpu_reset();
-       /*NOTREACHED*/
-}
-
-/*
- * Mapping table for core kernel memory. This memory is mapped at init
- * time with section mappings.
- */
-struct l1_sec_map {
-       vm_offset_t     va;
-       vm_offset_t     pa;
-       vm_size_t       size;
-       vm_prot_t       prot;
-       int             cache;
-} l1_sec_table[] = {
+static const struct pmap_devmap cats_devmap[] = {
        /* Map 1MB for CSR space */
        { DC21285_ARMCSR_VBASE,                 DC21285_ARMCSR_BASE,
            DC21285_ARMCSR_VSIZE,               VM_PROT_READ|VM_PROT_WRITE,
@@ -310,6 +212,14 @@
        { 0, 0, 0, 0, 0 }
 };
 
+#define MAX_PHYSMEM 4
+static struct boot_physmem cats_physmem[MAX_PHYSMEM];
+int ncats_physmem = 0;
+
+extern struct bus_space footbridge_pci_io_bs_tag;
+extern struct bus_space footbridge_pci_mem_bs_tag;
+void footbridge_pci_bs_tag_init(void);
+
 /*
  * u_int initarm(struct ebsaboot *bootinfo)
  *
@@ -328,9 +238,6 @@
 initarm(void *arm_bootargs)
 {
        struct ebsaboot *bootinfo = arm_bootargs;
-       int loop;
-       int loop1;
-       u_int l1pagetable;
        extern u_int cpu_get_control(void);
 
        /*
@@ -358,8 +265,10 @@
         * Once all the memory map changes are complete we can call consinit()
         * and not have to worry about things moving.
         */
+       pmap_devmap_bootstrap((vaddr_t)ebsabootinfo.bt_l1, cats_devmap);
+
 #ifdef FCOM_INIT_ARM
-        fcomcnattach(DC21285_ARMCSR_BASE, comcnspeed, comcnmode);
+       fcomcnattach(DC21285_ARMCSR_VBASE, comcnspeed, comcnmode);
 #endif
 
        /* Talk to the user */
@@ -387,37 +296,6 @@
        printf("bt_vers     = 0x%08x\n", ebsabootinfo.bt_vers);
        printf("bt_features = 0x%08x\n", ebsabootinfo.bt_features);
 #endif
-/*     {
-       int loop;
-       for (loop = 0; loop < 8; ++loop) {
-               printf("%08x\n", *(((int *)bootinfo)+loop));
-       }
-       }*/
-
-       /*
-        * Ok we have the following memory map
-        *
-        * virtual address == physical address apart from the areas:
-        * 0x00000000 -> 0x000fffff which is mapped to
-        * top 1MB of physical memory
-        * 0x00100000 -> 0x0fffffff which is mapped to
-        * physical addresses 0x00100000 -> 0x0fffffff
-        * 0x10000000 -> 0x1fffffff which is mapped to
-        * physical addresses 0x00000000 -> 0x0fffffff
-        * 0x20000000 -> 0xefffffff which is mapped to
-        * physical addresses 0x20000000 -> 0xefffffff
-        * 0xf0000000 -> 0xf03fffff which is mapped to
-        * physical addresses 0x00000000 -> 0x003fffff
-        *
-        * This means that the kernel is mapped suitably for continuing
-        * execution, all I/O is mapped 1:1 virtual to physical and
-        * physical memory is accessible.
-        *
-        * The initarm() has the responsibility for creating the kernel
-        * page tables.
-        * It must also set up various memory pointers that are used
-        * by pmap etc. 
-        */
 
        /*
         * Examine the boot args string for options we need to know about
@@ -425,186 +303,17 @@
         */
        process_kernel_args(ebsabootinfo.bt_args);
 
-       printf("initarm: Configuring system ...\n");
-
-       /*
-        * Set up the variables that define the availablilty of
-        * physical memory
-        */
-       physical_start = ebsabootinfo.bt_memstart;
-       physical_freestart = physical_start;
-       physical_end = ebsabootinfo.bt_memend;
-       physical_freeend = physical_end;
-       free_pages = (physical_end - physical_start) / PAGE_SIZE;
-    
-       physmem = (physical_end - physical_start) / PAGE_SIZE;
-
-       /* Tell the user about the memory */
-       printf("physmemory: %d pages at 0x%08lx -> 0x%08lx\n", physmem,
-           physical_start, physical_end - 1);
-
-       /*
-        * Ok the kernel occupies the bottom of physical memory.
-        * The first free page after the kernel can be found in
-        * ebsabootinfo->bt_memavail
-        * We now need to allocate some fixed page tables to get the kernel
-        * going.
-        * We allocate one page directory and a number page tables and store
-        * the physical addresses in the kernel_pt_table array.
-        *
-        * Ok the next bit of physical allocation may look complex but it is
-        * simple really. I have done it like this so that no memory gets
-        * wasted during the allocation of various pages and tables that are
-        * all different sizes.
-        * The start addresses will be page aligned.
-        * We allocate the kernel page directory on the first free 16KB boundry
-        * we find.
-        * We allocate the kernel page tables on the first 4KB boundry we find.
-        * Since we allocate at least 3 L2 pagetables we know that we must
-        * encounter at least one 16KB aligned address.
-        */
-
-#ifdef VERBOSE_INIT_ARM
-       printf("Allocating page tables");
-#endif
-
-       /* Update the address of the first free page of physical memory */
-       physical_freestart = ebsabootinfo.bt_memavail;
-       free_pages -= (physical_freestart - physical_start) / PAGE_SIZE;
-       
-#ifdef VERBOSE_INIT_ARM
-       printf(" above %p\n", (void *)physical_freestart);
-#endif
-       /* Define a macro to simplify memory allocation */
-#define        valloc_pages(var, np)                   \
-       alloc_pages((var).pv_pa, (np)); \
-       (var).pv_va = KERNEL_BASE + (var).pv_pa - physical_start;
-
-#define alloc_pages(var, np)                   \
-       (var) = physical_freestart;             \
-       physical_freestart += ((np) * PAGE_SIZE);\
-       free_pages -= (np);                     \
-       memset((char *)(var), 0, ((np) * PAGE_SIZE));
-
-       loop1 = 0;
-       for (loop = 0; loop <= NUM_KERNEL_PTS; ++loop) {
-               /* Are we 16KB aligned for an L1 ? */
-               if ((physical_freestart & (L1_TABLE_SIZE - 1)) == 0
-                   && kernel_l1pt.pv_pa == 0) {
-                       valloc_pages(kernel_l1pt, L1_TABLE_SIZE / PAGE_SIZE);
-               } else {
-                       valloc_pages(kernel_pt_table[loop1],
-                                       L2_TABLE_SIZE / PAGE_SIZE);
-                       ++loop1;                        
-               }
-       }



Home | Main Index | Thread Index | Old Index