ths | 5fafdf2 | 2007-09-16 21:08:06 +0000 | [diff] [blame] | 1 | /* |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 2 | * Arnewsh 5206 ColdFire system emulation. |
| 3 | * |
| 4 | * Copyright (c) 2007 CodeSourcery. |
| 5 | * |
Matthew Fernandez | 8e31bf3 | 2011-06-26 12:21:35 +1000 | [diff] [blame] | 6 | * This code is licensed under the GPL |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 7 | */ |
| 8 | |
Peter Maydell | d841666 | 2016-01-26 18:17:23 +0000 | [diff] [blame] | 9 | #include "qemu/osdep.h" |
Markus Armbruster | da34e65 | 2016-03-14 09:01:28 +0100 | [diff] [blame] | 10 | #include "qapi/error.h" |
Paolo Bonzini | 4771d75 | 2016-01-19 21:51:44 +0100 | [diff] [blame] | 11 | #include "cpu.h" |
Paolo Bonzini | 0d09e41 | 2013-02-05 17:06:20 +0100 | [diff] [blame] | 12 | #include "hw/m68k/mcf.h" |
Paolo Bonzini | 83c9f4c | 2013-02-04 15:40:22 +0100 | [diff] [blame] | 13 | #include "hw/boards.h" |
| 14 | #include "hw/loader.h" |
Blue Swirl | ca20cf3 | 2009-09-20 14:58:02 +0000 | [diff] [blame] | 15 | #include "elf.h" |
Paolo Bonzini | 022c62c | 2012-12-17 18:19:49 +0100 | [diff] [blame] | 16 | #include "exec/address-spaces.h" |
Markus Armbruster | c525436 | 2015-12-17 17:35:09 +0100 | [diff] [blame] | 17 | #include "qemu/error-report.h" |
Andreas Färber | 19c82aa | 2013-07-29 18:48:58 +0200 | [diff] [blame] | 18 | #include "sysemu/qtest.h" |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 19 | |
| 20 | #define KERNEL_LOAD_ADDR 0x10000 |
| 21 | #define AN5206_MBAR_ADDR 0x10000000 |
| 22 | #define AN5206_RAMBAR_ADDR 0x20000000 |
| 23 | |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 24 | /* Board init. */ |
| 25 | |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 26 | static void an5206_init(MachineState *machine) |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 27 | { |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 28 | ram_addr_t ram_size = machine->ram_size; |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 29 | const char *kernel_filename = machine->kernel_filename; |
Andreas Färber | 4025cfd | 2013-01-18 14:10:34 +0100 | [diff] [blame] | 30 | M68kCPU *cpu; |
Andreas Färber | 7927df3 | 2012-03-14 01:38:23 +0100 | [diff] [blame] | 31 | CPUM68KState *env; |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 32 | int kernel_size; |
| 33 | uint64_t elf_entry; |
Avi Kivity | a8170e5 | 2012-10-23 12:30:10 +0200 | [diff] [blame] | 34 | hwaddr entry; |
Avi Kivity | 72e4d25 | 2011-07-25 14:14:31 +0300 | [diff] [blame] | 35 | MemoryRegion *address_space_mem = get_system_memory(); |
| 36 | MemoryRegion *ram = g_new(MemoryRegion, 1); |
| 37 | MemoryRegion *sram = g_new(MemoryRegion, 1); |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 38 | |
Igor Mammedov | 25a20b3 | 2017-10-05 15:50:46 +0200 | [diff] [blame] | 39 | cpu = M68K_CPU(cpu_create(machine->cpu_type)); |
Andreas Färber | 4025cfd | 2013-01-18 14:10:34 +0100 | [diff] [blame] | 40 | env = &cpu->env; |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 41 | |
| 42 | /* Initialize CPU registers. */ |
| 43 | env->vbr = 0; |
| 44 | /* TODO: allow changing MBAR and RAMBAR. */ |
| 45 | env->mbar = AN5206_MBAR_ADDR | 1; |
| 46 | env->rambar0 = AN5206_RAMBAR_ADDR | 1; |
| 47 | |
| 48 | /* DRAM at address zero */ |
Dirk Müller | 1d5bfde | 2015-03-24 23:11:03 +0100 | [diff] [blame] | 49 | memory_region_allocate_system_memory(ram, NULL, "an5206.ram", ram_size); |
Avi Kivity | 72e4d25 | 2011-07-25 14:14:31 +0300 | [diff] [blame] | 50 | memory_region_add_subregion(address_space_mem, 0, ram); |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 51 | |
| 52 | /* Internal SRAM. */ |
Peter Maydell | 98a99ce | 2017-07-07 15:42:53 +0100 | [diff] [blame] | 53 | memory_region_init_ram(sram, NULL, "an5206.sram", 512, &error_fatal); |
Avi Kivity | 72e4d25 | 2011-07-25 14:14:31 +0300 | [diff] [blame] | 54 | memory_region_add_subregion(address_space_mem, AN5206_RAMBAR_ADDR, sram); |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 55 | |
Andreas Färber | 4025cfd | 2013-01-18 14:10:34 +0100 | [diff] [blame] | 56 | mcf5206_init(address_space_mem, AN5206_MBAR_ADDR, cpu); |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 57 | |
| 58 | /* Load kernel. */ |
| 59 | if (!kernel_filename) { |
Andreas Färber | 19c82aa | 2013-07-29 18:48:58 +0200 | [diff] [blame] | 60 | if (qtest_enabled()) { |
| 61 | return; |
| 62 | } |
Alistair Francis | 45876e9 | 2017-09-29 17:16:06 -0700 | [diff] [blame] | 63 | error_report("Kernel image must be specified"); |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 64 | exit(1); |
| 65 | } |
| 66 | |
Liam Merwick | 4366e1d | 2019-01-15 12:18:03 +0000 | [diff] [blame] | 67 | kernel_size = load_elf(kernel_filename, NULL, NULL, NULL, &elf_entry, |
Peter Crosthwaite | 7ef295e | 2016-03-04 11:30:21 +0000 | [diff] [blame] | 68 | NULL, NULL, 1, EM_68K, 0, 0); |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 69 | entry = elf_entry; |
| 70 | if (kernel_size < 0) { |
Max Filippov | 25bda50 | 2014-10-19 07:42:22 +0400 | [diff] [blame] | 71 | kernel_size = load_uimage(kernel_filename, &entry, NULL, NULL, |
| 72 | NULL, NULL); |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 73 | } |
| 74 | if (kernel_size < 0) { |
pbrook | dcac967 | 2009-04-09 20:05:49 +0000 | [diff] [blame] | 75 | kernel_size = load_image_targphys(kernel_filename, KERNEL_LOAD_ADDR, |
| 76 | ram_size - KERNEL_LOAD_ADDR); |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 77 | entry = KERNEL_LOAD_ADDR; |
| 78 | } |
| 79 | if (kernel_size < 0) { |
Alistair Francis | 45876e9 | 2017-09-29 17:16:06 -0700 | [diff] [blame] | 80 | error_report("Could not load kernel '%s'", kernel_filename); |
pbrook | 0633879 | 2007-05-23 19:58:11 +0000 | [diff] [blame] | 81 | exit(1); |
| 82 | } |
| 83 | |
| 84 | env->pc = entry; |
| 85 | } |
| 86 | |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 87 | static void an5206_machine_init(MachineClass *mc) |
Anthony Liguori | f80f9ec | 2009-05-20 18:38:09 -0500 | [diff] [blame] | 88 | { |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 89 | mc->desc = "Arnewsh 5206"; |
| 90 | mc->init = an5206_init; |
Igor Mammedov | 25a20b3 | 2017-10-05 15:50:46 +0200 | [diff] [blame] | 91 | mc->default_cpu_type = M68K_CPU_TYPE_NAME("m5206"); |
Anthony Liguori | f80f9ec | 2009-05-20 18:38:09 -0500 | [diff] [blame] | 92 | } |
| 93 | |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 94 | DEFINE_MACHINE("an5206", an5206_machine_init) |