Mercurial > hg > CbC > CbC_xv6
view src/main.c @ 367:650fac123133
...
author | anatofuz |
---|---|
date | Fri, 03 Jul 2020 21:21:38 +0900 |
parents | 3d7e1c9a852e |
children | 287581b5d348 |
line wrap: on
line source
// BSP support routine #include "types.h" #include "defs.h" #include "param.h" #include "arm.h" #include "proc.h" #include "memlayout.h" #include "mmu.h" #include "kernel.h" extern void* end; struct cpu cpus[NCPU]; struct cpu *cpu; #define MB (1024*1024) void kmain (void) { uint vectbl; cpu = &cpus[0]; uart_init (P2V(UART0)); // interrrupt vector table is in the middle of first 1MB. We use the left // over for page tables vectbl = P2V_WO (VEC_TBL & PDE_MASK); init_vmm (); kpt_freerange (align_up(&end, PT_SZ), vectbl); kpt_freerange (vectbl + PT_SZ, P2V_WO(INIT_KERNMAP)); paging_init (INIT_KERNMAP, PHYSTOP); kmem_init (); kmem_init2(P2V(INIT_KERNMAP), P2V(PHYSTOP)); kernel_context = calloc(sizeof(struct KernelContext), 1); initContext(&kernel_context->context); trap_init (); // vector table and stacks for models pic_init (P2V(VIC_BASE)); // interrupt controller uart_enable_rx (); // interrupt for uart consoleinit (); // console pinit (); // process (locks) binit (); // buffer cache fileinit (); // file table iinit (); // inode cache ideinit (); // ide (memory block device) timer_init (HZ); // the timer (ticker) sti (); userinit(); // first user process scheduler(); // start running processes }