|
20 | 20 | #include "qemu/osdep.h"
|
21 | 21 | #include "qemu/units.h"
|
22 | 22 |
|
| 23 | +#include "elf.h" |
23 | 24 | #include "hw/boards.h"
|
24 | 25 | #include "hw/char/serial.h"
|
25 | 26 | #include "hw/ide/pci.h"
|
@@ -551,10 +552,37 @@ static void boston_mach_init(MachineState *machine)
|
551 | 552 | exit(1);
|
552 | 553 | }
|
553 | 554 | } else if (machine->kernel_filename) {
|
554 |
| - fit_err = load_fit(&boston_fit_loader, machine->kernel_filename, s); |
555 |
| - if (fit_err) { |
556 |
| - error_report("unable to load FIT image"); |
557 |
| - exit(1); |
| 555 | + uint64_t kernel_entry, kernel_high, kernel_size; |
| 556 | + |
| 557 | + kernel_size = load_elf(machine->kernel_filename, NULL, |
| 558 | + cpu_mips_kseg0_to_phys, NULL, |
| 559 | + &kernel_entry, NULL, &kernel_high, |
| 560 | + NULL, 0, EM_MIPS, 1, 0); |
| 561 | + |
| 562 | + if (kernel_size) { |
| 563 | + hwaddr dtb_paddr = QEMU_ALIGN_UP(kernel_high, 64 * KiB); |
| 564 | + hwaddr dtb_vaddr = cpu_mips_phys_to_kseg0(NULL, dtb_paddr); |
| 565 | + |
| 566 | + s->kernel_entry = kernel_entry; |
| 567 | + if (machine->dtb) { |
| 568 | + int dt_size; |
| 569 | + g_autofree const void *dtb_file_data, *dtb_load_data; |
| 570 | + |
| 571 | + dtb_file_data = load_device_tree(machine->dtb, &dt_size); |
| 572 | + dtb_load_data = boston_fdt_filter(s, dtb_file_data, |
| 573 | + NULL, &dtb_vaddr); |
| 574 | + |
| 575 | + /* Calculate real fdt size after filter */ |
| 576 | + dt_size = fdt_totalsize(dtb_load_data); |
| 577 | + rom_add_blob_fixed("dtb", dtb_load_data, dt_size, dtb_paddr); |
| 578 | + } |
| 579 | + } else { |
| 580 | + /* Try to load file as FIT */ |
| 581 | + fit_err = load_fit(&boston_fit_loader, machine->kernel_filename, s); |
| 582 | + if (fit_err) { |
| 583 | + error_report("unable to load kernel image"); |
| 584 | + exit(1); |
| 585 | + } |
558 | 586 | }
|
559 | 587 |
|
560 | 588 | gen_firmware(memory_region_get_ram_ptr(flash) + 0x7c00000,
|
|
0 commit comments