sub clone_image {
my ($class, $scfg, $storeid, $volname, $vmid) = @_;
- die "not implemented";
+ my $snap = '__base__';
+
+ my ($vtype, $basename, $basevmid, undef, undef, $isBase) =
+ $class->parse_volname($volname);
+
+ die "clone_image only works on base images\n" if !$isBase;
+
+ my $name = &$find_free_diskname($storeid, $scfg, $vmid);
+
+ warn "clone $volname: $basename to $name\n";
+
+ my $newvol = "$basename/$name";
+
+ nexenta_request($scfg, 'clone', 'zvol', "$scfg->{pool}/$basename\@$snap", "$scfg->{pool}/$name");
+
+ nexenta_create_lu($scfg, $name);
+ nexenta_add_lun_mapping_entry($scfg, $name);
+
+ return $newvol;
}
sub alloc_image {