Matthew Booth
2010-Apr-07 10:08 UTC
[Libguestfs] [PATCH] Connection: Handle case of cdrom with no <source> element
CD-ROM devices don't necessarily have a <source> element in their libvirt domain XML, which caused an error. This fixes RHBZ#579676 --- lib/Sys/VirtV2V/Connection.pm | 103 ++++++++++++++++++++++------------------- 1 files changed, 56 insertions(+), 47 deletions(-) diff --git a/lib/Sys/VirtV2V/Connection.pm b/lib/Sys/VirtV2V/Connection.pm index a211662..c901b90 100644 --- a/lib/Sys/VirtV2V/Connection.pm +++ b/lib/Sys/VirtV2V/Connection.pm @@ -116,7 +116,8 @@ sub _storage_iterate my @paths; # A list of libvirt target device names my @devices; - foreach my $disk ($dom->findnodes('/domain/devices/disk')) { + + foreach my $disk ($dom->findnodes("/domain/devices/disk[\@device='disk']")) { my ($source_e) = $disk->findnodes('source'); my ($source) = $source_e->findnodes('@file | @dev'); @@ -125,55 +126,63 @@ sub _storage_iterate my ($dev) = $disk->findnodes('target/@dev'); defined($dev) or die("disk does not have a target device: \n". - $dom->toString()); + $dom->toString()); - # If the disk is a floppy or a cdrom, blank its source - my $device = $disk->getAttribute('device'); - if ($device eq 'floppy' || $device eq 'cdrom') { - $source_e->setAttribute($source->getName(), ''); - } + my $path = $source->getValue(); + + # Die if transfer required and no output target + die (user_message(__"No output target was specified")) + unless (defined($target)); + + # Fetch the remote storage + my $vol = $transfer->transfer($self, $path, $target); - else { - my $path = $source->getValue(); - - # Die if transfer required and no output target - die (user_message(__"No output target was specified")) - unless (defined($target)); - - # Fetch the remote storage - my $vol = $transfer->transfer($self, $path, $target); - - # Export the new path - $path = $vol->get_path(); - - # Find any existing driver element. - my ($driver) = $disk->findnodes('driver'); - - # Create a new driver element if none exists - unless (defined($driver)) { - $driver - $disk->getOwnerDocument()->createElement("driver"); - $disk->appendChild($driver); - } - $driver->setAttribute('name', 'qemu'); - $driver->setAttribute('type', $vol->get_format()); - - # Remove the @file or @dev attribute before adding a new one - $source_e->removeAttributeNode($source); - - # Set @file or @dev as appropriate - if ($vol->is_block()) - { - $disk->setAttribute('type', 'block'); - $source_e->setAttribute('dev', $path); - } else { - $disk->setAttribute('type', 'file'); - $source_e->setAttribute('file', $path); - } - - push(@paths, $path); - push(@devices, $dev->getNodeValue()); + # Export the new path + $path = $vol->get_path(); + + # Find any existing driver element. + my ($driver) = $disk->findnodes('driver'); + + # Create a new driver element if none exists + unless (defined($driver)) { + $driver + $disk->getOwnerDocument()->createElement("driver"); + $disk->appendChild($driver); } + $driver->setAttribute('name', 'qemu'); + $driver->setAttribute('type', $vol->get_format()); + + # Remove the @file or @dev attribute before adding a new one + $source_e->removeAttributeNode($source); + + # Set @file or @dev as appropriate + if ($vol->is_block()) { + $disk->setAttribute('type', 'block'); + $source_e->setAttribute('dev', $path); + } else { + $disk->setAttribute('type', 'file'); + $source_e->setAttribute('file', $path); + } + + push(@paths, $path); + push(@devices, $dev->getNodeValue()); + } + + # Blank the source of floppies or cdroms + foreach my $disk ($dom->findnodes('/domain/devices/disk'. + "[\@device='floppy' or \@device='cdrom']")) + { + my ($source_e) = $disk->findnodes('source'); + + # Nothing to do if there's no source element + next unless (defined($source_e)); + + # Blank file or dev as appropriate + my ($source) = $source_e->findnodes('@file | @dev'); + defined($source) or die("source element has neither dev nor file: \n". + $dom->toString()); + + $source_e->setAttribute($source->getName(), ''); } $self->{paths} = \@paths; -- 1.6.6.1
Richard W.M. Jones
2010-Apr-08 09:39 UTC
[Libguestfs] [PATCH] Connection: Handle case of cdrom with no <source> element
On Wed, Apr 07, 2010 at 11:08:47AM +0100, Matthew Booth wrote:> CD-ROM devices don't necessarily have a <source> element in their libvirt domain > XML, which caused an error. > > This fixes RHBZ#579676This looks good, ACK. Rich. -- Richard Jones, Virtualization Group, Red Hat http://people.redhat.com/~rjones New in Fedora 11: Fedora Windows cross-compiler. Compile Windows programs, test, and build Windows installers. Over 70 libraries supprt'd http://fedoraproject.org/wiki/MinGW http://www.annexia.org/fedora_mingw
Apparently Analagous Threads
- [PATCH] Add LocalCopy transfer method to transfer local files to a target
- [PATCH 1/2] Refactor guest and volume creation into Sys::VirtV2V::Target::LibVirt
- [PATCH 1/2] Fix remapping of block devices
- [PREVIEW ONLY] Refactor data transfer code
- [PATCH] Converter: Fixes to Xen metadata conversion