Changes in kernel/arch/ppc32/src/mm/frame.c [98000fb:7e752b2] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/arch/ppc32/src/mm/frame.c
r98000fb r7e752b2 27 27 */ 28 28 29 /** @addtogroup ppc32mm 29 /** @addtogroup ppc32mm 30 30 * @{ 31 31 */ … … 41 41 42 42 uintptr_t last_frame = 0; 43 memmap_t memmap; 43 44 44 45 void physmem_print(void) 45 46 { 46 unsigned int i;47 printf("[base ] [size ]\n"); 47 48 48 printf("Base Size\n"); 49 printf("---------- ----------\n"); 50 51 for (i = 0; i < bootinfo.memmap.count; i++) { 52 printf("%#10x %#10x\n", bootinfo.memmap.zones[i].start, 53 bootinfo.memmap.zones[i].size); 49 size_t i; 50 for (i = 0; i < memmap.cnt; i++) { 51 printf("%p %#0zx\n", memmap.zones[i].start, 52 memmap.zones[i].size); 54 53 } 55 54 } … … 59 58 pfn_t minconf = 2; 60 59 size_t i; 61 pfn_t start, conf;62 size_t size;63 60 64 for (i = 0; i < bootinfo.memmap.count; i++) { 65 start = ADDR2PFN(ALIGN_UP(bootinfo.memmap.zones[i].start, FRAME_SIZE)); 66 size = SIZE2FRAMES(ALIGN_DOWN(bootinfo.memmap.zones[i].size, FRAME_SIZE)); 61 for (i = 0; i < memmap.cnt; i++) { 62 /* To be safe, make the available zone possibly smaller */ 63 uintptr_t new_start = ALIGN_UP((uintptr_t) memmap.zones[i].start, 64 FRAME_SIZE); 65 size_t new_size = ALIGN_DOWN(memmap.zones[i].size - 66 (new_start - ((uintptr_t) memmap.zones[i].start)), FRAME_SIZE); 67 67 68 if ((minconf < start) || (minconf >= start + size)) 69 conf = start; 68 pfn_t pfn = ADDR2PFN(new_start); 69 size_t count = SIZE2FRAMES(new_size); 70 71 pfn_t conf; 72 if ((minconf < pfn) || (minconf >= pfn + count)) 73 conf = pfn; 70 74 else 71 75 conf = minconf; 72 76 73 zone_create(start, size, conf, 0); 74 if (last_frame < ALIGN_UP(bootinfo.memmap.zones[i].start + bootinfo.memmap.zones[i].size, FRAME_SIZE)) 75 last_frame = ALIGN_UP(bootinfo.memmap.zones[i].start + bootinfo.memmap.zones[i].size, FRAME_SIZE); 77 zone_create(pfn, count, conf, 0); 78 79 if (last_frame < ALIGN_UP(new_start + new_size, FRAME_SIZE)) 80 last_frame = ALIGN_UP(new_start + new_size, FRAME_SIZE); 76 81 } 77 82 … … 81 86 82 87 /* Mark the Page Hash Table frames as unavailable */ 83 uint32_t sdr1; 84 asm volatile ( 85 "mfsdr1 %0\n" 86 : "=r" (sdr1) 87 ); 88 frame_mark_unavailable(ADDR2PFN(sdr1 & 0xffff000), 16); // FIXME 88 uint32_t sdr1 = sdr1_get(); 89 90 // FIXME: compute size of PHT exactly 91 frame_mark_unavailable(ADDR2PFN(sdr1 & 0xffff000), 16); 89 92 } 90 93
Note:
See TracChangeset
for help on using the changeset viewer.