提交 791d81ca 创建 作者: Frans Kaashoek's avatar Frans Kaashoek

Merge branch 'page' of git+ssh://amsterdam.csail.mit.edu/home/am0/6.828/xv6 into page

...@@ -155,7 +155,7 @@ void uartputc(int); ...@@ -155,7 +155,7 @@ void uartputc(int);
void pminit(void); void pminit(void);
void ksegment(void); void ksegment(void);
void kvmalloc(void); void kvmalloc(void);
void vminit(void); void vmenable(void);
pde_t* setupkvm(void); pde_t* setupkvm(void);
char* uva2ka(pde_t*, char*); char* uva2ka(pde_t*, char*);
int allocuvm(pde_t*, char*, uint); int allocuvm(pde_t*, char*, uint);
......
...@@ -41,7 +41,7 @@ void ...@@ -41,7 +41,7 @@ void
mainc(void) mainc(void)
{ {
cprintf("\ncpu%d: starting xv6\n\n", cpu->id); cprintf("\ncpu%d: starting xv6\n\n", cpu->id);
kvmalloc(); // initialze the kernel page table kvmalloc(); // initialize the kernel page table
pinit(); // process table pinit(); // process table
tvinit(); // trap vectors tvinit(); // trap vectors
binit(); // buffer cache binit(); // buffer cache
...@@ -67,7 +67,7 @@ mpmain(void) ...@@ -67,7 +67,7 @@ mpmain(void)
ksegment(); ksegment();
lapicinit(cpunum()); lapicinit(cpunum());
} }
vminit(); // turn on paging vmenable(); // turn on paging
cprintf("cpu%d: starting\n", cpu->id); cprintf("cpu%d: starting\n", cpu->id);
idtinit(); // load idt register idtinit(); // load idt register
xchg(&cpu->booted, 1); xchg(&cpu->booted, 1);
......
...@@ -21,7 +21,6 @@ spinlock.c ...@@ -21,7 +21,6 @@ spinlock.c
proc.h proc.h
proc.c proc.c
swtch.S swtch.S
vm.c
kalloc.c kalloc.c
vm.c vm.c
......
...@@ -21,6 +21,7 @@ int dup(int); ...@@ -21,6 +21,7 @@ int dup(int);
int getpid(); int getpid();
char* sbrk(int); char* sbrk(int);
int sleep(int); int sleep(int);
int uptime();
// ulib.c // ulib.c
int stat(char*, struct stat*); int stat(char*, struct stat*);
......
...@@ -369,14 +369,13 @@ kvmalloc(void) ...@@ -369,14 +369,13 @@ kvmalloc(void)
// Turn on paging. // Turn on paging.
void void
vminit(void) vmenable(void)
{ {
uint cr0; uint cr0;
lcr3(PADDR(kpgdir)); switchkvm(); // load kpgdir into cr3
cr0 = rcr0(); cr0 = rcr0();
cr0 |= CR0_PE|CR0_PG|CR0_AM|CR0_WP|CR0_NE|CR0_TS|CR0_EM|CR0_MP; cr0 |= CR0_PG;
cr0 &= ~(CR0_TS|CR0_EM);
lcr0(cr0); lcr0(cr0);
} }
删除文件
这个 源代码变更 因为 太大 而不能显示。 你可以 浏览blob
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论