|
|
1.1 ! root 1: #include "config.h" ! 2: #include "kernel/kernel.h" ! 3: #include "arch/common/elf_boot.h" ! 4: #include "libopenbios/sys_info.h" ! 5: #include "context.h" ! 6: #include "boot.h" ! 7: ! 8: #define printf printk ! 9: #ifdef CONFIG_DEBUG_BOOT ! 10: #define debug printk ! 11: #else ! 12: #define debug(x...) ! 13: #endif ! 14: ! 15: uint64_t qemu_mem_size; ! 16: unsigned long va_shift; ! 17: ! 18: void collect_multiboot_info(struct sys_info *); ! 19: ! 20: void collect_sys_info(struct sys_info *info) ! 21: { ! 22: int i; ! 23: unsigned long long total = 0; ! 24: struct memrange *mmap; ! 25: ! 26: /* Pick up paramters given by bootloader to us */ ! 27: //info->boot_type = boot_ctx->eax; ! 28: //info->boot_data = boot_ctx->ebx; ! 29: info->boot_arg = boot_ctx->param[0]; ! 30: //debug("boot eax = %#lx\n", info->boot_type); ! 31: //debug("boot ebx = %#lx\n", info->boot_data); ! 32: info->boot_type = ELF_BHDR_MAGIC; ! 33: info->boot_data = virt_to_phys(&elf_image_notes); ! 34: debug("boot arg = %#lx\n", info->boot_arg); ! 35: ! 36: collect_elfboot_info(info); ! 37: #ifdef CONFIG_LINUXBIOS ! 38: collect_linuxbios_info(info); ! 39: #endif ! 40: #ifdef CONFIG_IMAGE_ELF_MULTIBOOT ! 41: collect_multiboot_info(info); ! 42: #endif ! 43: ! 44: if (!info->memrange) { ! 45: info->n_memranges = 1; ! 46: info->memrange = malloc(1 * sizeof(struct memrange)); ! 47: info->memrange[0].base = 0; ! 48: info->memrange[0].size = qemu_mem_size; ! 49: } ! 50: ! 51: debug("\n"); ! 52: mmap=info->memrange; ! 53: for (i = 0; i < info->n_memranges; i++) { ! 54: debug("%08lx-", (long)mmap[i].base); ! 55: debug("%08lx\n", (long)mmap[i].base + (long)mmap[i].size); ! 56: total += mmap[i].size; ! 57: } ! 58: debug("RAM %ld MB\n", (long)total >> 20); ! 59: }
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.