kern

changeset 76:0fe6eef16335

holy fuck, copy_on_write didn't actually do the copy!!!!
author John Tsiombikas <nuclear@member.fsf.org>
date Sat, 05 Nov 2011 04:53:46 +0200 (2011-11-05)
parents 8b21fe04ba2c
children a6513dc35f04
files src/main.c src/vm.c
diffstat 2 files changed, 13 insertions(+), 4 deletions(-) [+]
line diff
     1.1 --- a/src/main.c	Sat Oct 15 08:07:09 2011 +0300
     1.2 +++ b/src/main.c	Sat Nov 05 04:53:46 2011 +0200
     1.3 @@ -5,6 +5,7 @@
     1.4  #include "asmops.h"
     1.5  #include "segm.h"
     1.6  #include "intr.h"
     1.7 +#include "ata.h"
     1.8  #include "rtc.h"
     1.9  #include "timer.h"
    1.10  #include "mem.h"
    1.11 @@ -35,6 +36,9 @@
    1.12  	/* initialize paging and the virtual memory manager */
    1.13  	init_vm();
    1.14  
    1.15 +	/* initialize ATA disks */
    1.16 +	init_ata();
    1.17 +
    1.18  	/* initialize the timer and RTC */
    1.19  	init_timer();
    1.20  	init_rtc();
     2.1 --- a/src/vm.c	Sat Oct 15 08:07:09 2011 +0300
     2.2 +++ b/src/vm.c	Sat Nov 05 04:53:46 2011 +0200
     2.3 @@ -93,7 +93,7 @@
     2.4  	pglist[MEM_USER]->end = kmem_start_pg;
     2.5  	pglist[MEM_USER]->next = 0;
     2.6  
     2.7 -	/* temporaroly map something into every 1024th page of the kernel address
     2.8 +	/* temporarily map something into every 1024th page of the kernel address
     2.9  	 * space to force pre-allocation of all the kernel page-tables
    2.10  	 */
    2.11  	for(i=kmem_start_pg; i<pgtbl_base_pg; i+=1024) {
    2.12 @@ -607,7 +607,7 @@
    2.13  /* copy-on-write handler, called from pgfault above */
    2.14  static int copy_on_write(struct vm_page *page)
    2.15  {
    2.16 -	uint32_t newphys;
    2.17 +	int tmpvpg;
    2.18  	struct vm_page *newpage;
    2.19  	struct rbnode *vmnode;
    2.20  	struct process *p = get_current_proc();
    2.21 @@ -631,14 +631,19 @@
    2.22  	newpage->vpage = page->vpage;
    2.23  	newpage->flags = page->flags;
    2.24  
    2.25 -	if(!(newphys = alloc_phys_page())) {
    2.26 +	if(!(tmpvpg = pgalloc(1, MEM_KERNEL))) {
    2.27  		printf("copy_on_write: failed to allocate physical page\n");
    2.28  		/* XXX proper action: SIGSEGV */
    2.29  		return -1;
    2.30  	}
    2.31 -	newpage->ppage = ADDR_TO_PAGE(newphys);
    2.32 +	newpage->ppage = virt_to_phys_page(tmpvpg);
    2.33  	newpage->nref = 1;
    2.34  
    2.35 +	/* do the copy */
    2.36 +	memcpy((void*)PAGE_TO_ADDR(tmpvpg), (void*)PAGE_TO_ADDR(page->vpage), PGSIZE);
    2.37 +	unmap_page(tmpvpg);
    2.38 +	pgfree(tmpvpg, 1);
    2.39 +
    2.40  	/* set the new vm_page in the process vmmap */
    2.41  	vmnode = rb_findi(&p->vmmap, newpage->vpage);
    2.42  	assert(vmnode && vmnode->data == page);	/* shouldn't be able to fail */