]> git.proxmox.com Git - mirror_qemu.git/blame - hw/arm/palmetto-bmc.c
hw/arm: Add palmetto-bmc machine
[mirror_qemu.git] / hw / arm / palmetto-bmc.c
CommitLineData
327d8e4e
AJ
1/*
2 * OpenPOWER Palmetto BMC
3 *
4 * Andrew Jeffery <andrew@aj.id.au>
5 *
6 * Copyright 2016 IBM Corp.
7 *
8 * This code is licensed under the GPL version 2 or later. See
9 * the COPYING file in the top-level directory.
10 */
11
12#include "qemu/osdep.h"
13#include "exec/address-spaces.h"
14#include "hw/arm/arm.h"
15#include "hw/arm/ast2400.h"
16#include "hw/boards.h"
17
18static struct arm_boot_info palmetto_bmc_binfo = {
19 .loader_start = AST2400_SDRAM_BASE,
20 .board_id = 0,
21 .nb_cpus = 1,
22};
23
24typedef struct PalmettoBMCState {
25 AST2400State soc;
26 MemoryRegion ram;
27} PalmettoBMCState;
28
29static void palmetto_bmc_init(MachineState *machine)
30{
31 PalmettoBMCState *bmc;
32
33 bmc = g_new0(PalmettoBMCState, 1);
34 object_initialize(&bmc->soc, (sizeof(bmc->soc)), TYPE_AST2400);
35 object_property_add_child(OBJECT(machine), "soc", OBJECT(&bmc->soc),
36 &error_abort);
37
38 memory_region_allocate_system_memory(&bmc->ram, NULL, "ram", ram_size);
39 memory_region_add_subregion(get_system_memory(), AST2400_SDRAM_BASE,
40 &bmc->ram);
41 object_property_add_const_link(OBJECT(&bmc->soc), "ram", OBJECT(&bmc->ram),
42 &error_abort);
43 object_property_set_bool(OBJECT(&bmc->soc), true, "realized",
44 &error_abort);
45
46 palmetto_bmc_binfo.kernel_filename = machine->kernel_filename;
47 palmetto_bmc_binfo.initrd_filename = machine->initrd_filename;
48 palmetto_bmc_binfo.kernel_cmdline = machine->kernel_cmdline;
49 palmetto_bmc_binfo.ram_size = ram_size;
50 arm_load_kernel(ARM_CPU(first_cpu), &palmetto_bmc_binfo);
51}
52
53static void palmetto_bmc_machine_init(MachineClass *mc)
54{
55 mc->desc = "OpenPOWER Palmetto BMC";
56 mc->init = palmetto_bmc_init;
57 mc->max_cpus = 1;
58 mc->no_sdcard = 1;
59 mc->no_floppy = 1;
60 mc->no_cdrom = 1;
61 mc->no_sdcard = 1;
62 mc->no_parallel = 1;
63}
64
65DEFINE_MACHINE("palmetto-bmc", palmetto_bmc_machine_init);