pmap.c (209495) | pmap.c (209908) |
---|---|
1/*- 2 * Copyright (C) 2007-2009 Semihalf, Rafal Jaworowski <raj@semihalf.com> 3 * Copyright (C) 2006 Semihalf, Marian Balakowicz <m8@semihalf.com> 4 * All rights reserved. 5 * 6 * Redistribution and use in source and binary forms, with or without 7 * modification, are permitted provided that the following conditions 8 * are met: --- 35 unchanged lines hidden (view full) --- 44 * 0xc100_0000 - 0xc100_3fff : reserved for page zero/copy 45 * 0xc100_4000 - 0xc200_3fff : reserved for ptbl bufs 46 * 0xc200_4000 - 0xc200_8fff : guard page + kstack0 47 * 0xc200_9000 - 0xfeef_ffff : actual free KVA space 48 * 0xfef0_0000 - 0xffff_ffff : I/O devices region 49 */ 50 51#include <sys/cdefs.h> | 1/*- 2 * Copyright (C) 2007-2009 Semihalf, Rafal Jaworowski <raj@semihalf.com> 3 * Copyright (C) 2006 Semihalf, Marian Balakowicz <m8@semihalf.com> 4 * All rights reserved. 5 * 6 * Redistribution and use in source and binary forms, with or without 7 * modification, are permitted provided that the following conditions 8 * are met: --- 35 unchanged lines hidden (view full) --- 44 * 0xc100_0000 - 0xc100_3fff : reserved for page zero/copy 45 * 0xc100_4000 - 0xc200_3fff : reserved for ptbl bufs 46 * 0xc200_4000 - 0xc200_8fff : guard page + kstack0 47 * 0xc200_9000 - 0xfeef_ffff : actual free KVA space 48 * 0xfef0_0000 - 0xffff_ffff : I/O devices region 49 */ 50 51#include <sys/cdefs.h> |
52__FBSDID("$FreeBSD: head/sys/powerpc/booke/pmap.c 209495 2010-06-24 05:47:00Z marcel $"); | 52__FBSDID("$FreeBSD: head/sys/powerpc/booke/pmap.c 209908 2010-07-11 21:08:29Z raj $"); |
53 54#include <sys/types.h> 55#include <sys/param.h> 56#include <sys/malloc.h> 57#include <sys/ktr.h> 58#include <sys/proc.h> 59#include <sys/user.h> 60#include <sys/queue.h> --- 11 unchanged lines hidden (view full) --- 72#include <vm/vm_pageout.h> 73#include <vm/vm_extern.h> 74#include <vm/vm_object.h> 75#include <vm/vm_param.h> 76#include <vm/vm_map.h> 77#include <vm/vm_pager.h> 78#include <vm/uma.h> 79 | 53 54#include <sys/types.h> 55#include <sys/param.h> 56#include <sys/malloc.h> 57#include <sys/ktr.h> 58#include <sys/proc.h> 59#include <sys/user.h> 60#include <sys/queue.h> --- 11 unchanged lines hidden (view full) --- 72#include <vm/vm_pageout.h> 73#include <vm/vm_extern.h> 74#include <vm/vm_object.h> 75#include <vm/vm_param.h> 76#include <vm/vm_map.h> 77#include <vm/vm_pager.h> 78#include <vm/uma.h> 79 |
80#include <machine/bootinfo.h> | |
81#include <machine/cpu.h> 82#include <machine/pcb.h> 83#include <machine/platform.h> 84 85#include <machine/tlb.h> 86#include <machine/spr.h> 87#include <machine/vmparam.h> 88#include <machine/md_var.h> --- 2413 unchanged lines hidden (view full) --- 2502 /* Minidumps are based on virtual memory addresses. */ 2503 /* Nothing to do... */ 2504} 2505 2506struct pmap_md * 2507mmu_booke_scan_md(mmu_t mmu, struct pmap_md *prev) 2508{ 2509 static struct pmap_md md; | 80#include <machine/cpu.h> 81#include <machine/pcb.h> 82#include <machine/platform.h> 83 84#include <machine/tlb.h> 85#include <machine/spr.h> 86#include <machine/vmparam.h> 87#include <machine/md_var.h> --- 2413 unchanged lines hidden (view full) --- 2501 /* Minidumps are based on virtual memory addresses. */ 2502 /* Nothing to do... */ 2503} 2504 2505struct pmap_md * 2506mmu_booke_scan_md(mmu_t mmu, struct pmap_md *prev) 2507{ 2508 static struct pmap_md md; |
2510 struct bi_mem_region *mr; | |
2511 pte_t *pte; 2512 vm_offset_t va; 2513 2514 if (dumpsys_minidump) { 2515 md.md_paddr = ~0UL; /* Minidumps use virtual addresses. */ 2516 if (prev == NULL) { 2517 /* 1st: kernel .data and .bss. */ 2518 md.md_index = 1; --- 41 unchanged lines hidden (view full) --- 2560 break; 2561 } 2562 md.md_index = 3; 2563 /* FALLTHROUGH */ 2564 default: 2565 return (NULL); 2566 } 2567 } else { /* minidumps */ | 2509 pte_t *pte; 2510 vm_offset_t va; 2511 2512 if (dumpsys_minidump) { 2513 md.md_paddr = ~0UL; /* Minidumps use virtual addresses. */ 2514 if (prev == NULL) { 2515 /* 1st: kernel .data and .bss. */ 2516 md.md_index = 1; --- 41 unchanged lines hidden (view full) --- 2558 break; 2559 } 2560 md.md_index = 3; 2561 /* FALLTHROUGH */ 2562 default: 2563 return (NULL); 2564 } 2565 } else { /* minidumps */ |
2568 mr = bootinfo_mr(); | 2566 mem_regions(&physmem_regions, &physmem_regions_sz, 2567 &availmem_regions, &availmem_regions_sz); 2568 |
2569 if (prev == NULL) { 2570 /* first physical chunk. */ | 2569 if (prev == NULL) { 2570 /* first physical chunk. */ |
2571 md.md_paddr = mr->mem_base; 2572 md.md_size = mr->mem_size; | 2571 md.md_paddr = physmem_regions[0].mr_start; 2572 md.md_size = physmem_regions[0].mr_size; |
2573 md.md_vaddr = ~0UL; 2574 md.md_index = 1; | 2573 md.md_vaddr = ~0UL; 2574 md.md_index = 1; |
2575 } else if (md.md_index < bootinfo->bi_mem_reg_no) { 2576 md.md_paddr = mr[md.md_index].mem_base; 2577 md.md_size = mr[md.md_index].mem_size; | 2575 } else if (md.md_index < physmem_regions_sz) { 2576 md.md_paddr = physmem_regions[md.md_index].mr_start; 2577 md.md_size = physmem_regions[md.md_index].mr_size; |
2578 md.md_vaddr = ~0UL; 2579 md.md_index++; 2580 } else { 2581 /* There's no next physical chunk. */ 2582 return (NULL); 2583 } 2584 } 2585 --- 570 unchanged lines hidden --- | 2578 md.md_vaddr = ~0UL; 2579 md.md_index++; 2580 } else { 2581 /* There's no next physical chunk. */ 2582 return (NULL); 2583 } 2584 } 2585 --- 570 unchanged lines hidden --- |