Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/cats Revert previous - it wasn't complete.



details:   https://anonhg.NetBSD.org/src/rev/fbc02aeab466
branches:  trunk
changeset: 328474:fbc02aeab466
user:      skrll <skrll%NetBSD.org@localhost>
date:      Fri Apr 04 06:04:54 2014 +0000

description:
Revert previous - it wasn't complete.

diffstat:

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

diffs (truncated from 575 to 300 lines):

diff -r 93b1fc424469 -r fbc02aeab466 sys/arch/cats/cats/cats_machdep.c
--- a/sys/arch/cats/cats/cats_machdep.c Fri Apr 04 05:40:57 2014 +0000
+++ b/sys/arch/cats/cats/cats_machdep.c Fri Apr 04 06:04:54 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cats_machdep.c,v 1.79 2014/04/02 17:36:05 skrll Exp $  */
+/*     $NetBSD: cats_machdep.c,v 1.80 2014/04/04 06:04:54 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.79 2014/04/02 17:36:05 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cats_machdep.c,v 1.80 2014/04/04 06:04:54 skrll Exp $");
 
 #include "opt_ddb.h"
 #include "opt_modular.h"
@@ -74,8 +74,6 @@
 #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>
@@ -118,11 +116,30 @@
 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 */
 
@@ -173,7 +190,88 @@
 int comcnspeed = CONSPEED;
 int comcnmode = CONMODE;
 
-static const struct pmap_devmap cats_devmap[] = {
+
+/*
+ * 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[] = {
        /* Map 1MB for CSR space */
        { DC21285_ARMCSR_VBASE,                 DC21285_ARMCSR_BASE,
            DC21285_ARMCSR_VSIZE,               VM_PROT_READ|VM_PROT_WRITE,
@@ -212,14 +310,6 @@
        { 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)
  *
@@ -238,6 +328,9 @@
 initarm(void *arm_bootargs)
 {
        struct ebsaboot *bootinfo = arm_bootargs;
+       int loop;
+       int loop1;
+       u_int l1pagetable;
        extern u_int cpu_get_control(void);
 
        /*
@@ -265,10 +358,8 @@
         * 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_VBASE, comcnspeed, comcnmode);
+        fcomcnattach(DC21285_ARMCSR_BASE, comcnspeed, comcnmode);
 #endif
 
        /* Talk to the user */
@@ -296,6 +387,37 @@
        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
@@ -303,17 +425,186 @@
         */
        process_kernel_args(ebsabootinfo.bt_args);
 
-       arm32_bootmem_init(ebsabootinfo.bt_memstart,
-           ebsabootinfo.bt_memend - ebsabootinfo.bt_memstart,
-           ebsabootinfo.bt_memstart);
+       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);



Home | Main Index | Thread Index | Old Index