On 03/07/2015 09:00, Wu, Feng wrote: >>> > > struct irq_bypass_consumer { >>> > > struct list_head node; >>> > > void *token; >>> > > + unsigned irq; /*got from producer when registered*/ >>> > > void (*add_producer)(struct irq_bypass_producer *, >>> > > struct irq_bypass_consumer *); >>> > > void (*del_producer)(struct irq_bypass_producer *, >>> > > struct irq_bypass_consumer *); >>> > > + void (*update)(struct irq_bypass_consumer *); >>> > > }; >>> > > >>> > > 'update' is used to update the IRTE, while irq is initialized when >>> > > registered, which is used to find the right IRTE. >> > >> > Feel free to add "update" in your PI patches. I am not sure if "irq" >> > belongs here or in the containing struct. You can play with both and >> > submit the version that looks better to you. > Thanks for your review, Paolo. In my understanding, irq comes from > the producer side, while gsi belongs to the consumer, so we need > to get the irq from the producer somewhere. I am not sure adding > irq here is the good way, but what I need is in the 'update' function, > I have irq, gsi in hand. :) It's difficult to say without seeing the patches... The IRQ is stored in the producer already with Eric's changes. If you need to store the old IRQ value, because "update" needs to do something with it, then I think "irq" belongs in the container struct. Perhaps "update" needs to have a producer argument as well? Paolo -- 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