return $ids;
};
-my $fixup_missing_domain = sub {
+my sub normalize_pci_id {
my ($id) = @_;
-
$id = "0000:$id" if $id !~ m/^${domainregex}:/;
-
return $id;
};
sub get_mdev_types {
my ($id) = @_;
- $id = $fixup_missing_domain->($id);
+ $id = normalize_pci_id($id);
my $types = [];
my $available = int(file_read_firstline("$type_path/available_instances"));
my $description = PVE::Tools::file_get_contents("$type_path/description");
- push @$types, {
+ my $entry = {
type => $type,
description => $description,
available => $available,
};
+
+ my $name = file_read_firstline("$type_path/name");
+ $entry->{name} = $name if defined($name);
+
+ push @$types, $entry;
});
return $types;
}
die "Cannot find vfio-pci module!\n" if !-d $vfio_basedir;
- $pciid = $fixup_missing_domain->($pciid);
+ $pciid = normalize_pci_id($pciid);
# get IOMMU group devices
opendir(my $D, "$pcisysfs/devices/$pciid/iommu_group/devices/") || die "Cannot open iommu_group: $!\n";
sub pci_create_mdev_device {
my ($pciid, $uuid, $type) = @_;
- $pciid = $fixup_missing_domain->($pciid);
+ $pciid = normalize_pci_id($pciid);
my $basedir = "$pcisysfs/devices/$pciid";
my $mdev_dir = "$basedir/mdev_supported_types";
return undef;
}
-sub pci_cleanup_mdev_device {
- my ($pciid, $uuid) = @_;
-
- $pciid = $fixup_missing_domain->($pciid);
-
- my $basedir = "$pcisysfs/devices/$pciid/$uuid";
-
- if (! -e $basedir) {
- return 1; # no cleanup necessary if it does not exist
- }
-
- return file_write("$basedir/remove", "1");
-}
-
# encode the hostpci index and vmid into the uuid
sub generate_mdev_uuid {
my ($vmid, $index) = @_;