Hello! > >> + struct kvm_msi msi; > >> + > >> + msi.address_lo = e->msi.address_lo; > >> + msi.address_hi = e->msi.address_hi; > >> + msi.data = e->msi.data; > >> + if (e->type == KVM_IRQ_ROUTING_EXTENDED_MSI) { > >> + msi.devid = e->devid; > >> + msi.flags = KVM_MSI_VALID_DEVID; > >> + } > > > > Can't we make the assignment unconditional? > > The GICv2m MSI code does not care about the devid and the ITS code > > requires it. > > This simplifies quite something in the following patches. > > (This refers to the idea of not using the extended type in the kernel). > > How are we going to make sure the userspace provided a valid devid then? > - we have this info at user struct level: kvm_irq_routing_msi > - we wouldn't propagate the info at kernel struct level: > kvm_kernel_irq_routing_entry > - the only place where we could check the devid availability against the > need is at kvm_set_routing_entry I think (routing adaptation on ARM). > > What is going to happen if devid == 0 since unset? > > + if (msi->flags & KVM_MSI_VALID_DEVID) { > > + route.devid = msi->devid; > > + route.type = KVM_IRQ_ROUTING_EXTENDED_MSI; > > + } else if (!msi->flags) > > + return -EINVAL; > > I think we get away without using the extended type on the kernel side. > Within the kernel we don't have an ABI that we have to stick to forever, > so we can simplify things by re-using the existing type (no need to > check for both MSI types later). > So we always set the device ID, the only code that looks at it later is > the ITS emulation anyway, any other code path simply ignores that. Sorry for delayed reply, i'm a bit busy so cannot check all the emails in time... This is one more reason for using KVM_MSI_VALID_DEVID flag with KVM_IRQ_ROUTING_MSI. In this case you don't have to bother about those conditions and just copy devid + flags pair between route and MSI structures. 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