Hi! > > 3. KVM_SET_GSI_ROUTING - we use KVM_IRQ_ROUTING_EXTENDED_MSI plus devid > > Here we already have a type field with some users, so lets piggy-back on > this. We already have 'flags' there too. > Both ioctl extensions are coupled with a per-VM capability to let > userland know that it needs to provide a device ID. > Using flags on its own (without an explicit capability) is what I > opposed against, not flags in general. Ok, and in your next respin you'll add the capability, correct? So that we will finally have all pieces in place. > In case of KVM_SET_GSI_ROUTING it just seems awkward > to me to use a flag when a different type would do as well. Well, MSI vs "Extended MSI" are even not different types really. It's just MSI which has devid. And we *ALREADY* have VALID_DEVID flag. > But after all, I don't have a strong opinion on that matter, so if > others prefer using a flag I am also fine with that. So, ok, to be short... My vote is for flag, because it's already there and it keeps up with the style we already have. Eric, this is my final statement about it. It's up to you to accept or ignore. In qemu code flag is a little bit nicer because it's just stored in a variable and helps to avoid several if-else's (however small ones). Compare: --- cut --- kroute.gsi = virq; kroute.type = KVM_IRQ_ROUTING_MSI; kroute.u.msi.address_lo = (uint32_t)msg.address; kroute.u.msi.address_hi = msg.address >> 32; kroute.u.msi.data = le32_to_cpu(msg.data); kroute.flags = kvm_msi_flags; if (kroute.flags & KVM_MSI_VALID_DEVID) { kroute.u.msi.devid = (pci_bus_num(dev->bus) << 8) | dev->devfn; } --- cut --- and: --- cut --- kroute.gsi = virq; if (use_extended_msi) { kroute.u.msi.devid = (pci_bus_num(dev->bus) << 8) | dev->devfn; kroute.type = KVM_IRQ_ROUTING_EXTENDED_MSI; } else { kroute.type = KVM_IRQ_ROUTING_MSI; } kroute.u.msi.address_lo = (uint32_t)msg.address; kroute.u.msi.address_hi = msg.address >> 32; kroute.u.msi.data = le32_to_cpu(msg.data); kroute.flags = kvm_msi_flags; --- cut --- Kind regards, Pavel Fedin Expert Engineer Samsung Electronics Research center Russia -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html