b94eda4466
5347b524-evtchn-eliminate-64k-ports-limitation.patch 53aac342-x86-HVM-consolidate-and-sanitize-CR4-guest-reserved-bit-determination.patch 53b16cd4-VT-d-ATS-correct-and-clean-up-dev_invalidate_iotlb.patch 53b56de1-properly-reference-count-DOMCTL_-un-pausedomain-hypercalls.patch 53cfdcc7-avoid-crash-when-doing-shutdown-with-active-cpupools.patch 53cfddaf-x86-mem_event-validate-the-response-vcpu_id-before-acting-on-it.patch 53cfdde4-x86-mem_event-prevent-underflow-of-vcpu-pause-counts.patch - bnc#886801 - xl vncviewer: The first domu can be accessed by any id 53c9151b-Fix-xl-vncviewer-accesses-port-0-by-any-invalid-domid.patch - Upstream pygrub bug fix 5370e03b-pygrub-fix-error-handling-if-no-valid-partitions-are-found.patch - Fix pygrub to handle old 32 bit VMs pygrub-boot-legacy-sles.patch (Mike Latimer) - Remove xen-vmresync utility. It is an old Platespin Orchestrate utility that should have never been included in the Xen package. Updated xen.spec - Rework xen-destroy utility included in xen-utils bnc#885292 and bnc#886063 Updated xen-utils-0.1.tar.bz2 - bnc#886063 - Xen monitor fails (xl list --long output different from xm list --long output) - bnc#885292 - VirtualDomain: pid_status does not know how to check status on SLE12 OBS-URL: https://build.opensuse.org/package/show/Virtualization/xen?expand=0&rev=322
59 lines
2.3 KiB
Diff
59 lines
2.3 KiB
Diff
commit 3bcf91cbbd9a18db9ae7d594ffde7979774ed512
|
|
Author: Roger Pau Monne <roger.pau@xxxxxxxxxx>
|
|
Date: Wed Feb 12 11:15:17 2014 +0100
|
|
|
|
libxl: local attach support for PHY backends using scripts
|
|
|
|
Allow disks using the PHY backend to locally attach if using a script.
|
|
|
|
Signed-off-by: Roger Pau Monnà <roger.pau@xxxxxxxxxx>
|
|
Suggested-by: Ian Campbell <ian.campbell@xxxxxxxxxx>
|
|
|
|
|
|
Index: xen-4.4.0-testing/tools/libxl/libxl.c
|
|
===================================================================
|
|
--- xen-4.4.0-testing.orig/tools/libxl/libxl.c
|
|
+++ xen-4.4.0-testing/tools/libxl/libxl.c
|
|
@@ -2634,6 +2634,16 @@ void libxl__device_disk_local_initiate_a
|
|
|
|
switch (disk->backend) {
|
|
case LIBXL_DISK_BACKEND_PHY:
|
|
+ if (disk->script != NULL) {
|
|
+ LOG(DEBUG, "trying to locally attach PHY device %s with script %s",
|
|
+ disk->pdev_path, disk->script);
|
|
+ libxl__prepare_ao_device(ao, &dls->aodev);
|
|
+ dls->aodev.callback = local_device_attach_cb;
|
|
+ device_disk_add(egc, LIBXL_TOOLSTACK_DOMID, disk,
|
|
+ &dls->aodev, libxl__alloc_vdev,
|
|
+ (void *) blkdev_start);
|
|
+ return;
|
|
+ }
|
|
LIBXL__LOG(ctx, LIBXL__LOG_DEBUG, "locally attaching PHY disk %s",
|
|
disk->pdev_path);
|
|
dev = disk->pdev_path;
|
|
@@ -2713,7 +2723,7 @@ static void local_device_attach_cb(libxl
|
|
}
|
|
|
|
dev = GCSPRINTF("/dev/%s", disk->vdev);
|
|
- LOG(DEBUG, "locally attaching qdisk %s", dev);
|
|
+ LOG(DEBUG, "locally attached disk %s", dev);
|
|
|
|
rc = libxl__device_from_disk(gc, LIBXL_TOOLSTACK_DOMID, disk, &device);
|
|
if (rc < 0)
|
|
@@ -2753,6 +2763,7 @@ void libxl__device_disk_local_initiate_d
|
|
if (!dls->diskpath) goto out;
|
|
|
|
switch (disk->backend) {
|
|
+ case LIBXL_DISK_BACKEND_PHY:
|
|
case LIBXL_DISK_BACKEND_QDISK:
|
|
if (disk->vdev != NULL) {
|
|
GCNEW(device);
|
|
@@ -2770,7 +2781,6 @@ void libxl__device_disk_local_initiate_d
|
|
/* disk->vdev == NULL; fall through */
|
|
default:
|
|
/*
|
|
- * Nothing to do for PHYSTYPE_PHY.
|
|
* For other device types assume that the blktap2 process is
|
|
* needed by the soon to be started domain and do nothing.
|
|
*/
|