mirror of https://github.com/xqemu/xqemu.git
Machine queue, 2018-08-17
* Allow machine classes to specify if boot device suffixes should be ignored by get_boot_devices_list() * Tiny coding style fixup -----BEGIN PGP SIGNATURE----- iQIcBAABCAAGBQJbdxQCAAoJECgHk2+YTcWm6CkQAL78ScW5oGGe4DfDAoyTdru2 1ozDTQno4VY51ruAheIQgjpkLSjRHsE0LEw6Tpm8qA8h+3gta8vOACb+E5n9Aeew ZJ+FrFkvQvbIm8otlypnu7eR4xPojZdnheVmPv/VblMbl4bkYoeteyT/8OEmd1bl QOsvf31TTd76e/fwNQFh8o1SF18fBUp/5RpaEEaW5MC+zXHwz6Tt4rZGy9Wc5zGD 91qzGBC2LYhggDbw5katH5N2407siJquMkoGG8Vm4ThPN92LV6zpkB+NcPuAOgXy TypyPXpNvp+Ab757l0BYC0ic235B0EgXf7hO4aDBd1LCdDYJNr5TRarXAymnl2DA Vrn22GfniBHGLcitNz7Zhb8/XrTJYZ0vM03i6dsRdHnyy+ebeAvWHBUlP/oKfK6s 0fLrXKtPj7pwL1a5+J20aG5HlPI7kGhqG3sq9iix3RfZj5aBzZH5CoLtwE7c8fV8 6U/rOCJpnCr1WwlzLgXaqwFPPhrpLlsnE+A5f3hFEE74pLHhMMYvlJl7nMi+BBV9 UTQf6Hn+X1BH/bbdX7cK/GGYMelsB4/RzaY9sA1jgNIefa9svvwK+X2odp2IWMZt ZoMLCWFEJIx8iOVlkvwzJqxwxNZQ5c9MiWAfPP2xphTJfV9wSCPxfKuG/IKkZNRB +bxZxBxgBTxH/BEmn+hf =CBMg -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/ehabkost/tags/machine-next-pull-request' into staging Machine queue, 2018-08-17 * Allow machine classes to specify if boot device suffixes should be ignored by get_boot_devices_list() * Tiny coding style fixup # gpg: Signature made Fri 17 Aug 2018 19:29:22 BST # gpg: using RSA key 2807936F984DC5A6 # gpg: Good signature from "Eduardo Habkost <ehabkost@redhat.com>" # Primary key fingerprint: 5A32 2FD5 ABC4 D3DB ACCF D1AA 2807 936F 984D C5A6 * remotes/ehabkost/tags/machine-next-pull-request: fw_cfg: ignore suffixes in the bootdevice list dependent on machine class sysbus: always allow explicit_ofw_unit_address() to override address generation machine: Fix coding style at machine_run_board_init() Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
adaec191bf
|
@ -29,6 +29,7 @@
|
||||||
#include "qemu/error-report.h"
|
#include "qemu/error-report.h"
|
||||||
#include "sysemu/reset.h"
|
#include "sysemu/reset.h"
|
||||||
#include "hw/qdev-core.h"
|
#include "hw/qdev-core.h"
|
||||||
|
#include "hw/boards.h"
|
||||||
|
|
||||||
typedef struct FWBootEntry FWBootEntry;
|
typedef struct FWBootEntry FWBootEntry;
|
||||||
|
|
||||||
|
@ -208,11 +209,13 @@ DeviceState *get_boot_device(uint32_t position)
|
||||||
* memory pointed by "size" is assigned total length of the array in bytes
|
* memory pointed by "size" is assigned total length of the array in bytes
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
char *get_boot_devices_list(size_t *size, bool ignore_suffixes)
|
char *get_boot_devices_list(size_t *size)
|
||||||
{
|
{
|
||||||
FWBootEntry *i;
|
FWBootEntry *i;
|
||||||
size_t total = 0;
|
size_t total = 0;
|
||||||
char *list = NULL;
|
char *list = NULL;
|
||||||
|
MachineClass *mc = MACHINE_GET_CLASS(qdev_get_machine());
|
||||||
|
bool ignore_suffixes = mc->ignore_boot_device_suffixes;
|
||||||
|
|
||||||
QTAILQ_FOREACH(i, &fw_boot_order, link) {
|
QTAILQ_FOREACH(i, &fw_boot_order, link) {
|
||||||
char *devpath = NULL, *suffix = NULL;
|
char *devpath = NULL, *suffix = NULL;
|
||||||
|
|
|
@ -793,8 +793,9 @@ void machine_run_board_init(MachineState *machine)
|
||||||
MachineClass *machine_class = MACHINE_GET_CLASS(machine);
|
MachineClass *machine_class = MACHINE_GET_CLASS(machine);
|
||||||
|
|
||||||
numa_complete_configuration(machine);
|
numa_complete_configuration(machine);
|
||||||
if (nb_numa_nodes)
|
if (nb_numa_nodes) {
|
||||||
machine_numa_finish_cpu_init(machine);
|
machine_numa_finish_cpu_init(machine);
|
||||||
|
}
|
||||||
|
|
||||||
/* If the machine supports the valid_cpu_types check and the user
|
/* If the machine supports the valid_cpu_types check and the user
|
||||||
* specified a CPU with -cpu check here that the user CPU is supported.
|
* specified a CPU with -cpu check here that the user CPU is supported.
|
||||||
|
|
|
@ -293,16 +293,8 @@ static char *sysbus_get_fw_dev_path(DeviceState *dev)
|
||||||
{
|
{
|
||||||
SysBusDevice *s = SYS_BUS_DEVICE(dev);
|
SysBusDevice *s = SYS_BUS_DEVICE(dev);
|
||||||
SysBusDeviceClass *sbc = SYS_BUS_DEVICE_GET_CLASS(s);
|
SysBusDeviceClass *sbc = SYS_BUS_DEVICE_GET_CLASS(s);
|
||||||
/* for the explicit unit address fallback case: */
|
|
||||||
char *addr, *fw_dev_path;
|
char *addr, *fw_dev_path;
|
||||||
|
|
||||||
if (s->num_mmio) {
|
|
||||||
return g_strdup_printf("%s@" TARGET_FMT_plx, qdev_fw_name(dev),
|
|
||||||
s->mmio[0].addr);
|
|
||||||
}
|
|
||||||
if (s->num_pio) {
|
|
||||||
return g_strdup_printf("%s@i%04x", qdev_fw_name(dev), s->pio[0]);
|
|
||||||
}
|
|
||||||
if (sbc->explicit_ofw_unit_address) {
|
if (sbc->explicit_ofw_unit_address) {
|
||||||
addr = sbc->explicit_ofw_unit_address(s);
|
addr = sbc->explicit_ofw_unit_address(s);
|
||||||
if (addr) {
|
if (addr) {
|
||||||
|
@ -311,6 +303,13 @@ static char *sysbus_get_fw_dev_path(DeviceState *dev)
|
||||||
return fw_dev_path;
|
return fw_dev_path;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (s->num_mmio) {
|
||||||
|
return g_strdup_printf("%s@" TARGET_FMT_plx, qdev_fw_name(dev),
|
||||||
|
s->mmio[0].addr);
|
||||||
|
}
|
||||||
|
if (s->num_pio) {
|
||||||
|
return g_strdup_printf("%s@i%04x", qdev_fw_name(dev), s->pio[0]);
|
||||||
|
}
|
||||||
return g_strdup(qdev_fw_name(dev));
|
return g_strdup(qdev_fw_name(dev));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -861,7 +861,7 @@ static void fw_cfg_machine_reset(void *opaque)
|
||||||
void *ptr;
|
void *ptr;
|
||||||
size_t len;
|
size_t len;
|
||||||
FWCfgState *s = opaque;
|
FWCfgState *s = opaque;
|
||||||
char *bootindex = get_boot_devices_list(&len, false);
|
char *bootindex = get_boot_devices_list(&len);
|
||||||
|
|
||||||
ptr = fw_cfg_modify_file(s, "bootorder", (uint8_t *)bootindex, len);
|
ptr = fw_cfg_modify_file(s, "bootorder", (uint8_t *)bootindex, len);
|
||||||
g_free(ptr);
|
g_free(ptr);
|
||||||
|
|
|
@ -1160,7 +1160,7 @@ static void spapr_dt_chosen(sPAPRMachineState *spapr, void *fdt)
|
||||||
const char *boot_device = machine->boot_order;
|
const char *boot_device = machine->boot_order;
|
||||||
char *stdout_path = spapr_vio_stdout_path(spapr->vio_bus);
|
char *stdout_path = spapr_vio_stdout_path(spapr->vio_bus);
|
||||||
size_t cb = 0;
|
size_t cb = 0;
|
||||||
char *bootlist = get_boot_devices_list(&cb, true);
|
char *bootlist = get_boot_devices_list(&cb);
|
||||||
|
|
||||||
_FDT(chosen = fdt_add_subnode(fdt, 0, "chosen"));
|
_FDT(chosen = fdt_add_subnode(fdt, 0, "chosen"));
|
||||||
|
|
||||||
|
@ -3949,6 +3949,7 @@ static void spapr_machine_class_init(ObjectClass *oc, void *data)
|
||||||
InterruptStatsProviderClass *ispc = INTERRUPT_STATS_PROVIDER_CLASS(oc);
|
InterruptStatsProviderClass *ispc = INTERRUPT_STATS_PROVIDER_CLASS(oc);
|
||||||
|
|
||||||
mc->desc = "pSeries Logical Partition (PAPR compliant)";
|
mc->desc = "pSeries Logical Partition (PAPR compliant)";
|
||||||
|
mc->ignore_boot_device_suffixes = true;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We set up the default / latest behaviour here. The class_init
|
* We set up the default / latest behaviour here. The class_init
|
||||||
|
|
|
@ -206,6 +206,7 @@ struct MachineClass {
|
||||||
bool auto_enable_numa_with_memhp;
|
bool auto_enable_numa_with_memhp;
|
||||||
void (*numa_auto_assign_ram)(MachineClass *mc, NodeInfo *nodes,
|
void (*numa_auto_assign_ram)(MachineClass *mc, NodeInfo *nodes,
|
||||||
int nb_nodes, ram_addr_t size);
|
int nb_nodes, ram_addr_t size);
|
||||||
|
bool ignore_boot_device_suffixes;
|
||||||
|
|
||||||
HotplugHandler *(*get_hotplug_handler)(MachineState *machine,
|
HotplugHandler *(*get_hotplug_handler)(MachineState *machine,
|
||||||
DeviceState *dev);
|
DeviceState *dev);
|
||||||
|
|
|
@ -182,7 +182,7 @@ void hmp_info_usb(Monitor *mon, const QDict *qdict);
|
||||||
|
|
||||||
void add_boot_device_path(int32_t bootindex, DeviceState *dev,
|
void add_boot_device_path(int32_t bootindex, DeviceState *dev,
|
||||||
const char *suffix);
|
const char *suffix);
|
||||||
char *get_boot_devices_list(size_t *size, bool ignore_suffixes);
|
char *get_boot_devices_list(size_t *size);
|
||||||
|
|
||||||
DeviceState *get_boot_device(uint32_t position);
|
DeviceState *get_boot_device(uint32_t position);
|
||||||
void check_boot_index(int32_t bootindex, Error **errp);
|
void check_boot_index(int32_t bootindex, Error **errp);
|
||||||
|
|
Loading…
Reference in New Issue