ths | 5fafdf2 | 2007-09-16 21:08:06 +0000 | [diff] [blame] | 1 | /* |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 2 | * ARM RealView Baseboard System emulation. |
| 3 | * |
pbrook | a1bb27b | 2007-04-06 16:49:48 +0000 | [diff] [blame] | 4 | * Copyright (c) 2006-2007 CodeSourcery. |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 5 | * Written by Paul Brook |
| 6 | * |
Matthew Fernandez | 8e31bf3 | 2011-06-26 12:21:35 +1000 | [diff] [blame] | 7 | * This code is licensed under the GPL. |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 8 | */ |
| 9 | |
Peter Maydell | 12b1672 | 2015-12-07 16:23:45 +0000 | [diff] [blame] | 10 | #include "qemu/osdep.h" |
Markus Armbruster | da34e65 | 2016-03-14 09:01:28 +0100 | [diff] [blame] | 11 | #include "qapi/error.h" |
Paolo Bonzini | 4771d75 | 2016-01-19 21:51:44 +0100 | [diff] [blame] | 12 | #include "cpu.h" |
Paolo Bonzini | 83c9f4c | 2013-02-04 15:40:22 +0100 | [diff] [blame] | 13 | #include "hw/sysbus.h" |
Peter Maydell | 12ec8bd | 2019-05-23 14:47:43 +0100 | [diff] [blame] | 14 | #include "hw/arm/boot.h" |
Paolo Bonzini | 0d09e41 | 2013-02-05 17:06:20 +0100 | [diff] [blame] | 15 | #include "hw/arm/primecell.h" |
Zongyuan Li | d5c3eb5 | 2022-03-25 02:15:54 +0800 | [diff] [blame] | 16 | #include "hw/core/split-irq.h" |
Philippe Mathieu-Daudé | 66b03dc | 2019-04-12 18:54:13 +0200 | [diff] [blame] | 17 | #include "hw/net/lan9118.h" |
Philippe Mathieu-Daudé | 437cc27 | 2019-04-12 18:54:16 +0200 | [diff] [blame] | 18 | #include "hw/net/smc91c111.h" |
Paolo Bonzini | 83c9f4c | 2013-02-04 15:40:22 +0100 | [diff] [blame] | 19 | #include "hw/pci/pci.h" |
Zongyuan Li | d5c3eb5 | 2022-03-25 02:15:54 +0800 | [diff] [blame] | 20 | #include "hw/qdev-core.h" |
Paolo Bonzini | 1422e32 | 2012-10-24 08:43:34 +0200 | [diff] [blame] | 21 | #include "net/net.h" |
Paolo Bonzini | 9c17d61 | 2012-12-17 18:20:04 +0100 | [diff] [blame] | 22 | #include "sysemu/sysemu.h" |
Paolo Bonzini | 83c9f4c | 2013-02-04 15:40:22 +0100 | [diff] [blame] | 23 | #include "hw/boards.h" |
Paolo Bonzini | 0d09e41 | 2013-02-05 17:06:20 +0100 | [diff] [blame] | 24 | #include "hw/i2c/i2c.h" |
Peter Maydell | b5a3ca3 | 2014-03-17 16:31:45 +0000 | [diff] [blame] | 25 | #include "qemu/error-report.h" |
xiaoqiang zhao | f0d1d2c | 2016-06-06 16:59:31 +0100 | [diff] [blame] | 26 | #include "hw/char/pl011.h" |
Philippe Mathieu-Daudé | c2de81e | 2017-09-04 15:21:53 +0100 | [diff] [blame] | 27 | #include "hw/cpu/a9mpcore.h" |
| 28 | #include "hw/intc/realview_gic.h" |
Markus Armbruster | 64552b6 | 2019-08-12 07:23:42 +0200 | [diff] [blame] | 29 | #include "hw/irq.h" |
Philippe Mathieu-Daudé | 440c9f9 | 2020-06-17 09:25:30 +0200 | [diff] [blame] | 30 | #include "hw/i2c/arm_sbcon_i2c.h" |
Philippe Mathieu-Daudé | 26c607b | 2020-07-05 14:24:24 +0200 | [diff] [blame] | 31 | #include "hw/sd/sd.h" |
Martin Kletzander | b8ab030 | 2023-09-22 17:21:39 +0200 | [diff] [blame] | 32 | #include "audio/audio.h" |
Philippe Mathieu-Daudé | d780d05 | 2024-01-18 21:06:38 +0100 | [diff] [blame] | 33 | #include "target/arm/cpu-qom.h" |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 34 | |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 35 | #define SMP_BOOT_ADDR 0xe0000000 |
Evgeny Voevodin | 078758d | 2012-01-13 20:52:40 +0000 | [diff] [blame] | 36 | #define SMP_BOOTREG_ADDR 0x10000030 |
Paul Brook | eee4850 | 2009-11-20 00:45:54 +0000 | [diff] [blame] | 37 | |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 38 | /* Board init. */ |
| 39 | |
balrog | f93eb9f | 2008-04-14 20:27:51 +0000 | [diff] [blame] | 40 | static struct arm_boot_info realview_binfo = { |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 41 | .smp_loader_start = SMP_BOOT_ADDR, |
Evgeny Voevodin | 078758d | 2012-01-13 20:52:40 +0000 | [diff] [blame] | 42 | .smp_bootreg_addr = SMP_BOOTREG_ADDR, |
balrog | f93eb9f | 2008-04-14 20:27:51 +0000 | [diff] [blame] | 43 | }; |
| 44 | |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 45 | /* The following two lists must be consistent. */ |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 46 | enum realview_board_type { |
| 47 | BOARD_EB, |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 48 | BOARD_EB_MPCORE, |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 49 | BOARD_PB_A8, |
| 50 | BOARD_PBX_A9, |
| 51 | }; |
| 52 | |
Blue Swirl | d05ac8f | 2009-12-04 20:44:44 +0000 | [diff] [blame] | 53 | static const int realview_board_id[] = { |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 54 | 0x33b, |
| 55 | 0x33b, |
| 56 | 0x769, |
| 57 | 0x76d |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 58 | }; |
| 59 | |
Zongyuan Li | d5c3eb5 | 2022-03-25 02:15:54 +0800 | [diff] [blame] | 60 | static void split_irq_from_named(DeviceState *src, const char* outname, |
| 61 | qemu_irq out1, qemu_irq out2) { |
| 62 | DeviceState *splitter = qdev_new(TYPE_SPLIT_IRQ); |
| 63 | |
| 64 | qdev_prop_set_uint32(splitter, "num-lines", 2); |
| 65 | |
| 66 | qdev_realize_and_unref(splitter, NULL, &error_fatal); |
| 67 | |
| 68 | qdev_connect_gpio_out(splitter, 0, out1); |
| 69 | qdev_connect_gpio_out(splitter, 1, out2); |
| 70 | qdev_connect_gpio_out_named(src, outname, 0, |
| 71 | qdev_get_gpio_in(splitter, 0)); |
| 72 | } |
| 73 | |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 74 | static void realview_init(MachineState *machine, |
Peter Maydell | db4ff6f | 2012-10-30 07:45:07 +0000 | [diff] [blame] | 75 | enum realview_board_type board_type) |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 76 | { |
Andreas Färber | 9077f01 | 2012-05-14 03:50:56 +0200 | [diff] [blame] | 77 | ARMCPU *cpu = NULL; |
| 78 | CPUARMState *env; |
Avi Kivity | 35e8782 | 2011-10-02 17:04:26 +0200 | [diff] [blame] | 79 | MemoryRegion *sysmem = get_system_memory(); |
Nikita Belov | b1ab03a | 2014-12-11 12:07:52 +0000 | [diff] [blame] | 80 | MemoryRegion *ram_lo; |
Avi Kivity | 35e8782 | 2011-10-02 17:04:26 +0200 | [diff] [blame] | 81 | MemoryRegion *ram_hi = g_new(MemoryRegion, 1); |
| 82 | MemoryRegion *ram_alias = g_new(MemoryRegion, 1); |
| 83 | MemoryRegion *ram_hack = g_new(MemoryRegion, 1); |
Peter Maydell | 03a0e94 | 2011-10-28 10:55:38 +0100 | [diff] [blame] | 84 | DeviceState *dev, *sysctl, *gpio2, *pl041; |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 85 | SysBusDevice *busdev; |
Paul Brook | fe7e875 | 2009-05-14 22:35:08 +0100 | [diff] [blame] | 86 | qemu_irq pic[64]; |
David Gibson | 29b358f | 2013-06-06 18:48:51 +1000 | [diff] [blame] | 87 | PCIBus *pci_bus = NULL; |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 88 | NICInfo *nd; |
Philippe Mathieu-Daudé | 26c607b | 2020-07-05 14:24:24 +0200 | [diff] [blame] | 89 | DriveInfo *dinfo; |
Andreas Färber | a5c8285 | 2013-08-03 00:18:51 +0200 | [diff] [blame] | 90 | I2CBus *i2c; |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 91 | int n; |
Like Xu | cc7d44c | 2019-05-19 04:54:26 +0800 | [diff] [blame] | 92 | unsigned int smp_cpus = machine->smp.cpus; |
pbrook | 9ee6e8b | 2007-11-11 00:04:49 +0000 | [diff] [blame] | 93 | qemu_irq cpu_irq[4]; |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 94 | int is_mpcore = 0; |
| 95 | int is_pb = 0; |
Paul Brook | 26e92f6 | 2009-11-13 03:30:33 +0000 | [diff] [blame] | 96 | uint32_t proc_id = 0; |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 97 | uint32_t sys_id; |
| 98 | ram_addr_t low_ram_size; |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 99 | ram_addr_t ram_size = machine->ram_size; |
Peter Maydell | b5a3ca3 | 2014-03-17 16:31:45 +0000 | [diff] [blame] | 100 | hwaddr periphbase = 0; |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 101 | |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 102 | switch (board_type) { |
| 103 | case BOARD_EB: |
| 104 | break; |
| 105 | case BOARD_EB_MPCORE: |
| 106 | is_mpcore = 1; |
Peter Maydell | b5a3ca3 | 2014-03-17 16:31:45 +0000 | [diff] [blame] | 107 | periphbase = 0x10100000; |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 108 | break; |
| 109 | case BOARD_PB_A8: |
| 110 | is_pb = 1; |
| 111 | break; |
| 112 | case BOARD_PBX_A9: |
| 113 | is_mpcore = 1; |
| 114 | is_pb = 1; |
Peter Maydell | b5a3ca3 | 2014-03-17 16:31:45 +0000 | [diff] [blame] | 115 | periphbase = 0x1f000000; |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 116 | break; |
| 117 | } |
Peter Maydell | b5a3ca3 | 2014-03-17 16:31:45 +0000 | [diff] [blame] | 118 | |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 119 | for (n = 0; n < smp_cpus; n++) { |
Igor Mammedov | ba1ba5c | 2017-09-13 18:04:57 +0200 | [diff] [blame] | 120 | Object *cpuobj = object_new(machine->cpu_type); |
Peter Maydell | b5a3ca3 | 2014-03-17 16:31:45 +0000 | [diff] [blame] | 121 | |
Greg Bellows | 61e2f35 | 2014-12-15 17:09:51 -0600 | [diff] [blame] | 122 | /* By default A9,A15 and ARM1176 CPUs have EL3 enabled. This board |
| 123 | * does not currently support EL3 so the CPU EL3 property is disabled |
| 124 | * before realization. |
| 125 | */ |
Daniel P. Berrangé | efba159 | 2020-09-14 14:56:17 +0100 | [diff] [blame] | 126 | if (object_property_find(cpuobj, "has_el3")) { |
Markus Armbruster | 5325cc3 | 2020-07-07 18:05:54 +0200 | [diff] [blame] | 127 | object_property_set_bool(cpuobj, "has_el3", false, &error_fatal); |
Greg Bellows | 61e2f35 | 2014-12-15 17:09:51 -0600 | [diff] [blame] | 128 | } |
| 129 | |
Peter Maydell | b5a3ca3 | 2014-03-17 16:31:45 +0000 | [diff] [blame] | 130 | if (is_pb && is_mpcore) { |
Markus Armbruster | 5325cc3 | 2020-07-07 18:05:54 +0200 | [diff] [blame] | 131 | object_property_set_int(cpuobj, "reset-cbar", periphbase, |
Markus Armbruster | 007b065 | 2015-09-11 15:04:45 +0200 | [diff] [blame] | 132 | &error_fatal); |
Peter Maydell | b5a3ca3 | 2014-03-17 16:31:45 +0000 | [diff] [blame] | 133 | } |
| 134 | |
Markus Armbruster | ce189ab | 2020-06-10 07:32:45 +0200 | [diff] [blame] | 135 | qdev_realize(DEVICE(cpuobj), NULL, &error_fatal); |
Peter Maydell | b5a3ca3 | 2014-03-17 16:31:45 +0000 | [diff] [blame] | 136 | |
| 137 | cpu_irq[n] = qdev_get_gpio_in(DEVICE(cpuobj), ARM_CPU_IRQ); |
bellard | aaed909 | 2007-11-10 15:15:54 +0000 | [diff] [blame] | 138 | } |
Peter Maydell | b5a3ca3 | 2014-03-17 16:31:45 +0000 | [diff] [blame] | 139 | cpu = ARM_CPU(first_cpu); |
Andreas Färber | 9077f01 | 2012-05-14 03:50:56 +0200 | [diff] [blame] | 140 | env = &cpu->env; |
Paul Brook | 26e92f6 | 2009-11-13 03:30:33 +0000 | [diff] [blame] | 141 | if (arm_feature(env, ARM_FEATURE_V7)) { |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 142 | if (is_mpcore) { |
| 143 | proc_id = 0x0c000000; |
| 144 | } else { |
| 145 | proc_id = 0x0e000000; |
| 146 | } |
Paul Brook | 26e92f6 | 2009-11-13 03:30:33 +0000 | [diff] [blame] | 147 | } else if (arm_feature(env, ARM_FEATURE_V6K)) { |
| 148 | proc_id = 0x06000000; |
| 149 | } else if (arm_feature(env, ARM_FEATURE_V6)) { |
| 150 | proc_id = 0x04000000; |
| 151 | } else { |
| 152 | proc_id = 0x02000000; |
| 153 | } |
bellard | aaed909 | 2007-11-10 15:15:54 +0000 | [diff] [blame] | 154 | |
Paul Brook | 21a8894 | 2009-12-21 20:19:12 +0000 | [diff] [blame] | 155 | if (is_pb && ram_size > 0x20000000) { |
| 156 | /* Core tile RAM. */ |
Nikita Belov | b1ab03a | 2014-12-11 12:07:52 +0000 | [diff] [blame] | 157 | ram_lo = g_new(MemoryRegion, 1); |
Paul Brook | 21a8894 | 2009-12-21 20:19:12 +0000 | [diff] [blame] | 158 | low_ram_size = ram_size - 0x20000000; |
| 159 | ram_size = 0x20000000; |
Peter Maydell | 98a99ce | 2017-07-07 15:42:53 +0100 | [diff] [blame] | 160 | memory_region_init_ram(ram_lo, NULL, "realview.lowmem", low_ram_size, |
Markus Armbruster | f8ed85a | 2015-09-11 16:51:43 +0200 | [diff] [blame] | 161 | &error_fatal); |
Avi Kivity | 35e8782 | 2011-10-02 17:04:26 +0200 | [diff] [blame] | 162 | memory_region_add_subregion(sysmem, 0x20000000, ram_lo); |
Paul Brook | 21a8894 | 2009-12-21 20:19:12 +0000 | [diff] [blame] | 163 | } |
| 164 | |
Peter Maydell | 98a99ce | 2017-07-07 15:42:53 +0100 | [diff] [blame] | 165 | memory_region_init_ram(ram_hi, NULL, "realview.highmem", ram_size, |
Markus Armbruster | f8ed85a | 2015-09-11 16:51:43 +0200 | [diff] [blame] | 166 | &error_fatal); |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 167 | low_ram_size = ram_size; |
| 168 | if (low_ram_size > 0x10000000) |
| 169 | low_ram_size = 0x10000000; |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 170 | /* SDRAM at address zero. */ |
Paolo Bonzini | 2c9b15c | 2013-06-06 05:41:28 -0400 | [diff] [blame] | 171 | memory_region_init_alias(ram_alias, NULL, "realview.alias", |
Avi Kivity | 35e8782 | 2011-10-02 17:04:26 +0200 | [diff] [blame] | 172 | ram_hi, 0, low_ram_size); |
| 173 | memory_region_add_subregion(sysmem, 0, ram_alias); |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 174 | if (is_pb) { |
| 175 | /* And again at a high address. */ |
Avi Kivity | 35e8782 | 2011-10-02 17:04:26 +0200 | [diff] [blame] | 176 | memory_region_add_subregion(sysmem, 0x70000000, ram_hi); |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 177 | } else { |
| 178 | ram_size = low_ram_size; |
| 179 | } |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 180 | |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 181 | sys_id = is_pb ? 0x01780500 : 0xc1400400; |
Markus Armbruster | 3e80f69 | 2020-06-10 07:31:58 +0200 | [diff] [blame] | 182 | sysctl = qdev_new("realview_sysctl"); |
Peter Maydell | 26883c6 | 2011-02-21 20:57:53 +0000 | [diff] [blame] | 183 | qdev_prop_set_uint32(sysctl, "sys_id", sys_id); |
Peter Maydell | 26883c6 | 2011-02-21 20:57:53 +0000 | [diff] [blame] | 184 | qdev_prop_set_uint32(sysctl, "proc_id", proc_id); |
Markus Armbruster | 3c6ef47 | 2020-06-10 07:32:34 +0200 | [diff] [blame] | 185 | sysbus_realize_and_unref(SYS_BUS_DEVICE(sysctl), &error_fatal); |
Andreas Färber | 1356b98 | 2013-01-20 02:47:33 +0100 | [diff] [blame] | 186 | sysbus_mmio_map(SYS_BUS_DEVICE(sysctl), 0, 0x10000000); |
pbrook | 9ee6e8b | 2007-11-11 00:04:49 +0000 | [diff] [blame] | 187 | |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 188 | if (is_mpcore) { |
Markus Armbruster | 3e80f69 | 2020-06-10 07:31:58 +0200 | [diff] [blame] | 189 | dev = qdev_new(is_pb ? TYPE_A9MPCORE_PRIV : "realview_mpcore"); |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 190 | qdev_prop_set_uint32(dev, "num-cpu", smp_cpus); |
Andreas Färber | 1356b98 | 2013-01-20 02:47:33 +0100 | [diff] [blame] | 191 | busdev = SYS_BUS_DEVICE(dev); |
Markus Armbruster | 3c6ef47 | 2020-06-10 07:32:34 +0200 | [diff] [blame] | 192 | sysbus_realize_and_unref(busdev, &error_fatal); |
Peter Maydell | 96eacf6 | 2012-02-16 09:56:09 +0000 | [diff] [blame] | 193 | sysbus_mmio_map(busdev, 0, periphbase); |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 194 | for (n = 0; n < smp_cpus; n++) { |
| 195 | sysbus_connect_irq(busdev, n, cpu_irq[n]); |
| 196 | } |
Peter Maydell | 96eacf6 | 2012-02-16 09:56:09 +0000 | [diff] [blame] | 197 | sysbus_create_varargs("l2x0", periphbase + 0x2000, NULL); |
| 198 | /* Both A9 and 11MPCore put the GIC CPU i/f at base + 0x100 */ |
| 199 | realview_binfo.gic_cpu_if_addr = periphbase + 0x100; |
pbrook | 9ee6e8b | 2007-11-11 00:04:49 +0000 | [diff] [blame] | 200 | } else { |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 201 | uint32_t gic_addr = is_pb ? 0x1e000000 : 0x10040000; |
| 202 | /* For now just create the nIRQ GIC, and ignore the others. */ |
Philippe Mathieu-Daudé | c2de81e | 2017-09-04 15:21:53 +0100 | [diff] [blame] | 203 | dev = sysbus_create_simple(TYPE_REALVIEW_GIC, gic_addr, cpu_irq[0]); |
Paul Brook | fe7e875 | 2009-05-14 22:35:08 +0100 | [diff] [blame] | 204 | } |
| 205 | for (n = 0; n < 64; n++) { |
Paul Brook | 067a3dd | 2009-05-26 14:56:11 +0100 | [diff] [blame] | 206 | pic[n] = qdev_get_gpio_in(dev, n); |
pbrook | 9ee6e8b | 2007-11-11 00:04:49 +0000 | [diff] [blame] | 207 | } |
| 208 | |
Markus Armbruster | 3e80f69 | 2020-06-10 07:31:58 +0200 | [diff] [blame] | 209 | pl041 = qdev_new("pl041"); |
Peter Maydell | 03a0e94 | 2011-10-28 10:55:38 +0100 | [diff] [blame] | 210 | qdev_prop_set_uint32(pl041, "nc_fifo_depth", 512); |
Martin Kletzander | b8ab030 | 2023-09-22 17:21:39 +0200 | [diff] [blame] | 211 | if (machine->audiodev) { |
| 212 | qdev_prop_set_string(pl041, "audiodev", machine->audiodev); |
| 213 | } |
Markus Armbruster | 3c6ef47 | 2020-06-10 07:32:34 +0200 | [diff] [blame] | 214 | sysbus_realize_and_unref(SYS_BUS_DEVICE(pl041), &error_fatal); |
Andreas Färber | 1356b98 | 2013-01-20 02:47:33 +0100 | [diff] [blame] | 215 | sysbus_mmio_map(SYS_BUS_DEVICE(pl041), 0, 0x10004000); |
| 216 | sysbus_connect_irq(SYS_BUS_DEVICE(pl041), 0, pic[19]); |
Peter Maydell | 03a0e94 | 2011-10-28 10:55:38 +0100 | [diff] [blame] | 217 | |
Paul Brook | 86394e9 | 2009-05-14 22:35:07 +0100 | [diff] [blame] | 218 | sysbus_create_simple("pl050_keyboard", 0x10006000, pic[20]); |
| 219 | sysbus_create_simple("pl050_mouse", 0x10007000, pic[21]); |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 220 | |
Peter Maydell | 9bca0ed | 2018-04-20 15:52:43 +0100 | [diff] [blame] | 221 | pl011_create(0x10009000, pic[12], serial_hd(0)); |
| 222 | pl011_create(0x1000a000, pic[13], serial_hd(1)); |
| 223 | pl011_create(0x1000b000, pic[14], serial_hd(2)); |
| 224 | pl011_create(0x1000c000, pic[15], serial_hd(3)); |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 225 | |
| 226 | /* DMA controller is optional, apparently. */ |
Markus Armbruster | 3e80f69 | 2020-06-10 07:31:58 +0200 | [diff] [blame] | 227 | dev = qdev_new("pl081"); |
Markus Armbruster | 5325cc3 | 2020-07-07 18:05:54 +0200 | [diff] [blame] | 228 | object_property_set_link(OBJECT(dev), "downstream", OBJECT(sysmem), |
Peter Maydell | 112a829 | 2018-08-20 11:24:33 +0100 | [diff] [blame] | 229 | &error_fatal); |
Peter Maydell | 112a829 | 2018-08-20 11:24:33 +0100 | [diff] [blame] | 230 | busdev = SYS_BUS_DEVICE(dev); |
Markus Armbruster | 3c6ef47 | 2020-06-10 07:32:34 +0200 | [diff] [blame] | 231 | sysbus_realize_and_unref(busdev, &error_fatal); |
Peter Maydell | 112a829 | 2018-08-20 11:24:33 +0100 | [diff] [blame] | 232 | sysbus_mmio_map(busdev, 0, 0x10030000); |
| 233 | sysbus_connect_irq(busdev, 0, pic[24]); |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 234 | |
Paul Brook | 6a824ec | 2009-05-14 22:35:07 +0100 | [diff] [blame] | 235 | sysbus_create_simple("sp804", 0x10011000, pic[4]); |
| 236 | sysbus_create_simple("sp804", 0x10012000, pic[5]); |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 237 | |
Peter Maydell | 26883c6 | 2011-02-21 20:57:53 +0000 | [diff] [blame] | 238 | sysbus_create_simple("pl061", 0x10013000, pic[6]); |
| 239 | sysbus_create_simple("pl061", 0x10014000, pic[7]); |
| 240 | gpio2 = sysbus_create_simple("pl061", 0x10015000, pic[8]); |
| 241 | |
Peter Maydell | acb9b72 | 2011-07-22 15:36:54 +0000 | [diff] [blame] | 242 | sysbus_create_simple("pl111", 0x10020000, pic[23]); |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 243 | |
Peter Maydell | 26883c6 | 2011-02-21 20:57:53 +0000 | [diff] [blame] | 244 | dev = sysbus_create_varargs("pl181", 0x10005000, pic[17], pic[18], NULL); |
| 245 | /* Wire up MMC card detect and read-only signals. These have |
| 246 | * to go to both the PL061 GPIO and the sysctl register. |
| 247 | * Note that the PL181 orders these lines (readonly,inserted) |
| 248 | * and the PL061 has them the other way about. Also the card |
| 249 | * detect line is inverted. |
| 250 | */ |
Zongyuan Li | d5c3eb5 | 2022-03-25 02:15:54 +0800 | [diff] [blame] | 251 | split_irq_from_named(dev, "card-read-only", |
| 252 | qdev_get_gpio_in(sysctl, ARM_SYSCTL_GPIO_MMC_WPROT), |
| 253 | qdev_get_gpio_in(gpio2, 1)); |
| 254 | |
| 255 | split_irq_from_named(dev, "card-inserted", |
| 256 | qdev_get_gpio_in(sysctl, ARM_SYSCTL_GPIO_MMC_CARDIN), |
| 257 | qemu_irq_invert(qdev_get_gpio_in(gpio2, 0))); |
| 258 | |
Markus Armbruster | 64eaa82 | 2021-11-17 17:33:58 +0100 | [diff] [blame] | 259 | dinfo = drive_get(IF_SD, 0, 0); |
Philippe Mathieu-Daudé | 26c607b | 2020-07-05 14:24:24 +0200 | [diff] [blame] | 260 | if (dinfo) { |
| 261 | DeviceState *card; |
| 262 | |
| 263 | card = qdev_new(TYPE_SD_CARD); |
| 264 | qdev_prop_set_drive_err(card, "drive", blk_by_legacy_dinfo(dinfo), |
| 265 | &error_fatal); |
| 266 | qdev_realize_and_unref(card, qdev_get_child_bus(dev, "sd-bus"), |
| 267 | &error_fatal); |
| 268 | } |
pbrook | a1bb27b | 2007-04-06 16:49:48 +0000 | [diff] [blame] | 269 | |
Paul Brook | a63bdb3 | 2009-05-14 22:35:07 +0100 | [diff] [blame] | 270 | sysbus_create_simple("pl031", 0x10017000, pic[10]); |
pbrook | 7e1543c | 2007-06-30 17:32:17 +0000 | [diff] [blame] | 271 | |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 272 | if (!is_pb) { |
Markus Armbruster | 3e80f69 | 2020-06-10 07:31:58 +0200 | [diff] [blame] | 273 | dev = qdev_new("realview_pci"); |
Andreas Färber | 1356b98 | 2013-01-20 02:47:33 +0100 | [diff] [blame] | 274 | busdev = SYS_BUS_DEVICE(dev); |
Markus Armbruster | 3c6ef47 | 2020-06-10 07:32:34 +0200 | [diff] [blame] | 275 | sysbus_realize_and_unref(busdev, &error_fatal); |
Peter Maydell | 7468d73 | 2013-04-19 11:15:20 +0100 | [diff] [blame] | 276 | sysbus_mmio_map(busdev, 0, 0x10019000); /* PCI controller registers */ |
Peter Maydell | a2bff78 | 2013-04-19 11:15:20 +0100 | [diff] [blame] | 277 | sysbus_mmio_map(busdev, 1, 0x60000000); /* PCI self-config */ |
| 278 | sysbus_mmio_map(busdev, 2, 0x61000000); /* PCI config */ |
| 279 | sysbus_mmio_map(busdev, 3, 0x62000000); /* PCI I/O */ |
Peter Maydell | 89a32d3 | 2013-04-19 11:15:20 +0100 | [diff] [blame] | 280 | sysbus_mmio_map(busdev, 4, 0x63000000); /* PCI memory window 1 */ |
| 281 | sysbus_mmio_map(busdev, 5, 0x64000000); /* PCI memory window 2 */ |
| 282 | sysbus_mmio_map(busdev, 6, 0x68000000); /* PCI memory window 3 */ |
Peter Maydell | 7d6e771 | 2011-09-01 18:36:53 +0100 | [diff] [blame] | 283 | sysbus_connect_irq(busdev, 0, pic[48]); |
| 284 | sysbus_connect_irq(busdev, 1, pic[49]); |
| 285 | sysbus_connect_irq(busdev, 2, pic[50]); |
| 286 | sysbus_connect_irq(busdev, 3, pic[51]); |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 287 | pci_bus = (PCIBus *)qdev_get_child_bus(dev, "pci"); |
Eduardo Habkost | 4bcbe0b | 2016-06-08 17:50:25 -0300 | [diff] [blame] | 288 | if (machine_usb(machine)) { |
Gerd Hoffmann | afb9a60 | 2012-03-07 15:06:32 +0100 | [diff] [blame] | 289 | pci_create_simple(pci_bus, -1, "pci-ohci"); |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 290 | } |
| 291 | n = drive_get_max_bus(IF_SCSI); |
| 292 | while (n >= 0) { |
Mark Cave-Ayland | 877eb21 | 2018-09-19 18:20:58 +0100 | [diff] [blame] | 293 | dev = DEVICE(pci_create_simple(pci_bus, -1, "lsi53c895a")); |
| 294 | lsi53c8xx_handle_legacy_cmdline(dev); |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 295 | n--; |
| 296 | } |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 297 | } |
aliguori | 0ae18ce | 2009-01-13 19:39:36 +0000 | [diff] [blame] | 298 | |
David Woodhouse | cd53991 | 2023-10-23 09:37:35 +0100 | [diff] [blame^] | 299 | nd = qemu_find_nic_info(is_pb ? "lan9118" : "smc91c111", true, NULL); |
| 300 | if (nd) { |
| 301 | if (is_pb) { |
| 302 | lan9118_init(nd, 0x4e000000, pic[28]); |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 303 | } else { |
David Woodhouse | cd53991 | 2023-10-23 09:37:35 +0100 | [diff] [blame^] | 304 | smc91c111_init(0x4e000000, pic[28]); |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 305 | } |
| 306 | } |
| 307 | |
David Woodhouse | cd53991 | 2023-10-23 09:37:35 +0100 | [diff] [blame^] | 308 | if (pci_bus) { |
| 309 | pci_init_nic_devices(pci_bus, "rtl8139"); |
| 310 | } |
| 311 | |
Philippe Mathieu-Daudé | 550da1c | 2023-01-10 09:25:06 +0100 | [diff] [blame] | 312 | dev = sysbus_create_simple(TYPE_ARM_SBCON_I2C, 0x10002000, NULL); |
Andreas Färber | a5c8285 | 2013-08-03 00:18:51 +0200 | [diff] [blame] | 313 | i2c = (I2CBus *)qdev_get_child_bus(dev, "i2c"); |
Philippe Mathieu-Daudé | 1373b15 | 2020-07-06 00:41:53 +0200 | [diff] [blame] | 314 | i2c_slave_create_simple(i2c, "ds1338", 0x68); |
Paul Brook | eee4850 | 2009-11-20 00:45:54 +0000 | [diff] [blame] | 315 | |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 316 | /* Memory map for RealView Emulation Baseboard: */ |
| 317 | /* 0x10000000 System registers. */ |
| 318 | /* 0x10001000 System controller. */ |
Paul Brook | eee4850 | 2009-11-20 00:45:54 +0000 | [diff] [blame] | 319 | /* 0x10002000 Two-Wire Serial Bus. */ |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 320 | /* 0x10003000 Reserved. */ |
| 321 | /* 0x10004000 AACI. */ |
| 322 | /* 0x10005000 MCI. */ |
| 323 | /* 0x10006000 KMI0. */ |
| 324 | /* 0x10007000 KMI1. */ |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 325 | /* 0x10008000 Character LCD. (EB) */ |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 326 | /* 0x10009000 UART0. */ |
| 327 | /* 0x1000a000 UART1. */ |
| 328 | /* 0x1000b000 UART2. */ |
| 329 | /* 0x1000c000 UART3. */ |
| 330 | /* 0x1000d000 SSPI. */ |
| 331 | /* 0x1000e000 SCI. */ |
| 332 | /* 0x1000f000 Reserved. */ |
| 333 | /* 0x10010000 Watchdog. */ |
| 334 | /* 0x10011000 Timer 0+1. */ |
| 335 | /* 0x10012000 Timer 2+3. */ |
| 336 | /* 0x10013000 GPIO 0. */ |
| 337 | /* 0x10014000 GPIO 1. */ |
| 338 | /* 0x10015000 GPIO 2. */ |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 339 | /* 0x10002000 Two-Wire Serial Bus - DVI. (PB) */ |
pbrook | 7e1543c | 2007-06-30 17:32:17 +0000 | [diff] [blame] | 340 | /* 0x10017000 RTC. */ |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 341 | /* 0x10018000 DMC. */ |
| 342 | /* 0x10019000 PCI controller config. */ |
| 343 | /* 0x10020000 CLCD. */ |
| 344 | /* 0x10030000 DMA Controller. */ |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 345 | /* 0x10040000 GIC1. (EB) */ |
| 346 | /* 0x10050000 GIC2. (EB) */ |
| 347 | /* 0x10060000 GIC3. (EB) */ |
| 348 | /* 0x10070000 GIC4. (EB) */ |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 349 | /* 0x10080000 SMC. */ |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 350 | /* 0x1e000000 GIC1. (PB) */ |
| 351 | /* 0x1e001000 GIC2. (PB) */ |
| 352 | /* 0x1e002000 GIC3. (PB) */ |
| 353 | /* 0x1e003000 GIC4. (PB) */ |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 354 | /* 0x40000000 NOR flash. */ |
| 355 | /* 0x44000000 DoC flash. */ |
| 356 | /* 0x48000000 SRAM. */ |
| 357 | /* 0x4c000000 Configuration flash. */ |
| 358 | /* 0x4e000000 Ethernet. */ |
| 359 | /* 0x4f000000 USB. */ |
| 360 | /* 0x50000000 PISMO. */ |
| 361 | /* 0x54000000 PISMO. */ |
| 362 | /* 0x58000000 PISMO. */ |
| 363 | /* 0x5c000000 PISMO. */ |
| 364 | /* 0x60000000 PCI. */ |
Peter Maydell | a2bff78 | 2013-04-19 11:15:20 +0100 | [diff] [blame] | 365 | /* 0x60000000 PCI Self Config. */ |
| 366 | /* 0x61000000 PCI Config. */ |
| 367 | /* 0x62000000 PCI IO. */ |
| 368 | /* 0x63000000 PCI mem 0. */ |
| 369 | /* 0x64000000 PCI mem 1. */ |
| 370 | /* 0x68000000 PCI mem 2. */ |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 371 | |
pbrook | 7ffab4d | 2009-04-09 17:15:18 +0000 | [diff] [blame] | 372 | /* ??? Hack to map an additional page of ram for the secondary CPU |
| 373 | startup code. I guess this works on real hardware because the |
| 374 | BootROM happens to be in ROM/flash or in memory that isn't clobbered |
| 375 | until after Linux boots the secondary CPUs. */ |
Peter Maydell | 98a99ce | 2017-07-07 15:42:53 +0100 | [diff] [blame] | 376 | memory_region_init_ram(ram_hack, NULL, "realview.hack", 0x1000, |
Markus Armbruster | f8ed85a | 2015-09-11 16:51:43 +0200 | [diff] [blame] | 377 | &error_fatal); |
Avi Kivity | 35e8782 | 2011-10-02 17:04:26 +0200 | [diff] [blame] | 378 | memory_region_add_subregion(sysmem, SMP_BOOT_ADDR, ram_hack); |
pbrook | 7ffab4d | 2009-04-09 17:15:18 +0000 | [diff] [blame] | 379 | |
balrog | f93eb9f | 2008-04-14 20:27:51 +0000 | [diff] [blame] | 380 | realview_binfo.ram_size = ram_size; |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 381 | realview_binfo.board_id = realview_board_id[board_type]; |
Paul Brook | 21a8894 | 2009-12-21 20:19:12 +0000 | [diff] [blame] | 382 | realview_binfo.loader_start = (board_type == BOARD_PB_A8 ? 0x70000000 : 0); |
Philippe Mathieu-Daudé | f0109f7 | 2023-10-25 08:59:09 +0200 | [diff] [blame] | 383 | arm_load_kernel(cpu, machine, &realview_binfo); |
pbrook | e69954b | 2006-09-23 17:40:58 +0000 | [diff] [blame] | 384 | } |
| 385 | |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 386 | static void realview_eb_init(MachineState *machine) |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 387 | { |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 388 | realview_init(machine, BOARD_EB); |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 389 | } |
| 390 | |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 391 | static void realview_eb_mpcore_init(MachineState *machine) |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 392 | { |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 393 | realview_init(machine, BOARD_EB_MPCORE); |
Paul Brook | c988bfa | 2009-11-13 04:31:22 +0000 | [diff] [blame] | 394 | } |
| 395 | |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 396 | static void realview_pb_a8_init(MachineState *machine) |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 397 | { |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 398 | realview_init(machine, BOARD_PB_A8); |
Paul Brook | 0ef849d | 2009-11-16 17:06:43 +0000 | [diff] [blame] | 399 | } |
| 400 | |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 401 | static void realview_pbx_a9_init(MachineState *machine) |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 402 | { |
Marcel Apfelbaum | 3ef9622 | 2014-05-07 17:42:57 +0300 | [diff] [blame] | 403 | realview_init(machine, BOARD_PBX_A9); |
Paul Brook | f7c7032 | 2009-11-19 16:45:21 +0000 | [diff] [blame] | 404 | } |
| 405 | |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 406 | static void realview_eb_class_init(ObjectClass *oc, void *data) |
Anthony Liguori | f80f9ec | 2009-05-20 18:38:09 -0500 | [diff] [blame] | 407 | { |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 408 | MachineClass *mc = MACHINE_CLASS(oc); |
| 409 | |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 410 | mc->desc = "ARM RealView Emulation Baseboard (ARM926EJ-S)"; |
| 411 | mc->init = realview_eb_init; |
| 412 | mc->block_default_type = IF_SCSI; |
Peter Maydell | 4672cbd | 2017-09-07 13:54:54 +0100 | [diff] [blame] | 413 | mc->ignore_memory_transaction_failures = true; |
Igor Mammedov | ba1ba5c | 2017-09-13 18:04:57 +0200 | [diff] [blame] | 414 | mc->default_cpu_type = ARM_CPU_TYPE_NAME("arm926"); |
Martin Kletzander | b8ab030 | 2023-09-22 17:21:39 +0200 | [diff] [blame] | 415 | |
| 416 | machine_add_audiodev_property(mc); |
Anthony Liguori | f80f9ec | 2009-05-20 18:38:09 -0500 | [diff] [blame] | 417 | } |
| 418 | |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 419 | static const TypeInfo realview_eb_type = { |
| 420 | .name = MACHINE_TYPE_NAME("realview-eb"), |
| 421 | .parent = TYPE_MACHINE, |
| 422 | .class_init = realview_eb_class_init, |
| 423 | }; |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 424 | |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 425 | static void realview_eb_mpcore_class_init(ObjectClass *oc, void *data) |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 426 | { |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 427 | MachineClass *mc = MACHINE_CLASS(oc); |
| 428 | |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 429 | mc->desc = "ARM RealView Emulation Baseboard (ARM11MPCore)"; |
| 430 | mc->init = realview_eb_mpcore_init; |
| 431 | mc->block_default_type = IF_SCSI; |
| 432 | mc->max_cpus = 4; |
Peter Maydell | 4672cbd | 2017-09-07 13:54:54 +0100 | [diff] [blame] | 433 | mc->ignore_memory_transaction_failures = true; |
Igor Mammedov | ba1ba5c | 2017-09-13 18:04:57 +0200 | [diff] [blame] | 434 | mc->default_cpu_type = ARM_CPU_TYPE_NAME("arm11mpcore"); |
Martin Kletzander | b8ab030 | 2023-09-22 17:21:39 +0200 | [diff] [blame] | 435 | |
| 436 | machine_add_audiodev_property(mc); |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 437 | } |
| 438 | |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 439 | static const TypeInfo realview_eb_mpcore_type = { |
| 440 | .name = MACHINE_TYPE_NAME("realview-eb-mpcore"), |
| 441 | .parent = TYPE_MACHINE, |
| 442 | .class_init = realview_eb_mpcore_class_init, |
| 443 | }; |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 444 | |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 445 | static void realview_pb_a8_class_init(ObjectClass *oc, void *data) |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 446 | { |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 447 | MachineClass *mc = MACHINE_CLASS(oc); |
| 448 | |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 449 | mc->desc = "ARM RealView Platform Baseboard for Cortex-A8"; |
| 450 | mc->init = realview_pb_a8_init; |
Peter Maydell | 4672cbd | 2017-09-07 13:54:54 +0100 | [diff] [blame] | 451 | mc->ignore_memory_transaction_failures = true; |
Igor Mammedov | ba1ba5c | 2017-09-13 18:04:57 +0200 | [diff] [blame] | 452 | mc->default_cpu_type = ARM_CPU_TYPE_NAME("cortex-a8"); |
Martin Kletzander | b8ab030 | 2023-09-22 17:21:39 +0200 | [diff] [blame] | 453 | |
| 454 | machine_add_audiodev_property(mc); |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 455 | } |
| 456 | |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 457 | static const TypeInfo realview_pb_a8_type = { |
| 458 | .name = MACHINE_TYPE_NAME("realview-pb-a8"), |
| 459 | .parent = TYPE_MACHINE, |
| 460 | .class_init = realview_pb_a8_class_init, |
| 461 | }; |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 462 | |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 463 | static void realview_pbx_a9_class_init(ObjectClass *oc, void *data) |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 464 | { |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 465 | MachineClass *mc = MACHINE_CLASS(oc); |
| 466 | |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 467 | mc->desc = "ARM RealView Platform Baseboard Explore for Cortex-A9"; |
| 468 | mc->init = realview_pbx_a9_init; |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 469 | mc->max_cpus = 4; |
Peter Maydell | 4672cbd | 2017-09-07 13:54:54 +0100 | [diff] [blame] | 470 | mc->ignore_memory_transaction_failures = true; |
Igor Mammedov | ba1ba5c | 2017-09-13 18:04:57 +0200 | [diff] [blame] | 471 | mc->default_cpu_type = ARM_CPU_TYPE_NAME("cortex-a9"); |
Martin Kletzander | b8ab030 | 2023-09-22 17:21:39 +0200 | [diff] [blame] | 472 | |
| 473 | machine_add_audiodev_property(mc); |
Eduardo Habkost | e264d29 | 2015-09-04 15:37:08 -0300 | [diff] [blame] | 474 | } |
| 475 | |
Andreas Färber | 8a661ae | 2015-09-19 10:49:44 +0200 | [diff] [blame] | 476 | static const TypeInfo realview_pbx_a9_type = { |
| 477 | .name = MACHINE_TYPE_NAME("realview-pbx-a9"), |
| 478 | .parent = TYPE_MACHINE, |
| 479 | .class_init = realview_pbx_a9_class_init, |
| 480 | }; |
| 481 | |
| 482 | static void realview_machine_init(void) |
| 483 | { |
| 484 | type_register_static(&realview_eb_type); |
| 485 | type_register_static(&realview_eb_mpcore_type); |
| 486 | type_register_static(&realview_pb_a8_type); |
| 487 | type_register_static(&realview_pbx_a9_type); |
| 488 | } |
| 489 | |
Eduardo Habkost | 0e6aac8 | 2016-02-16 18:59:04 -0200 | [diff] [blame] | 490 | type_init(realview_machine_init) |