From: Christian Borntraeger Date: Tue, 18 Jun 2013 12:31:52 +0000 (+0200) Subject: s390/ipl: Fix boot order X-Git-Tag: v1.5.3~52 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5e2053dd159bf979a266f0a615a5d821a58bd06b;p=thirdparty%2Fqemu.git s390/ipl: Fix boot order The latest ipl code adaptions collided with some of the virtio refactoring rework. This resulted in always booting the first disk. Let's fix booting from a given ID. The new code also checks for command lines without bootindex to avoid random behaviour when accessing dev_st (==0). Signed-off-by: Christian Borntraeger Reviewed-by: Andreas Färber Signed-off-by: Alexander Graf (cherry picked from commit 5c8ded6ef55761e80353f42d8e59c6e233a2f51a) Signed-off-by: Michael Roth --- diff --git a/hw/s390x/ipl.c b/hw/s390x/ipl.c index 0aeb003c9d5..d69adb2f5b0 100644 --- a/hw/s390x/ipl.c +++ b/hw/s390x/ipl.c @@ -154,17 +154,19 @@ static void s390_ipl_reset(DeviceState *dev) env->psw.mask = IPL_PSW_MASK; if (!ipl->kernel) { - /* booting firmware, tell what device to boot from */ + /* Tell firmware, if there is a preferred boot device */ + env->regs[7] = -1; DeviceState *dev_st = get_boot_device(0); - VirtioCcwDevice *ccw_dev = (VirtioCcwDevice *) object_dynamic_cast( - OBJECT(&(dev_st->parent_obj)), "virtio-blk-ccw"); - - if (ccw_dev) { - env->regs[7] = ccw_dev->sch->cssid << 24 | - ccw_dev->sch->ssid << 16 | - ccw_dev->sch->devno; - } else { - env->regs[7] = -1; + if (dev_st) { + VirtioCcwDevice *ccw_dev = (VirtioCcwDevice *) object_dynamic_cast( + OBJECT(qdev_get_parent_bus(dev_st)->parent), + TYPE_VIRTIO_CCW_DEVICE); + + if (ccw_dev) { + env->regs[7] = ccw_dev->sch->cssid << 24 | + ccw_dev->sch->ssid << 16 | + ccw_dev->sch->devno; + } } }