[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH 11/28] ARM: GICv3: forward pending LPIs to guests
>>> On 02.03.17 at 21:56, <julien.grall@xxxxxxx> wrote: > Ping? I'd like the question to be sorted out before Andre is sending a > new version. > > On 02/15/2017 09:25 PM, Stefano Stabellini wrote: >> On Wed, 15 Feb 2017, Julien Grall wrote: >>> Hi Stefano, >>> >>> On 14/02/17 21:00, Stefano Stabellini wrote: >>>> On Mon, 30 Jan 2017, Andre Przywara wrote: >>>>> +/* >>>>> + * Handle incoming LPIs, which are a bit special, because they are >>>>> potentially >>>>> + * numerous and also only get injected into guests. Treat them specially >>>>> here, >>>>> + * by just looking up their target vCPU and virtual LPI number and hand >>>>> it >>>>> + * over to the injection function. >>>>> + */ >>>>> +void do_LPI(unsigned int lpi) >>>>> +{ >>>>> + struct domain *d; >>>>> + union host_lpi *hlpip, hlpi; >>>>> + struct vcpu *vcpu; >>>>> + >>>>> + WRITE_SYSREG32(lpi, ICC_EOIR1_EL1); >>>>> + >>>>> + hlpip = gic_get_host_lpi(lpi); >>>>> + if ( !hlpip ) >>>>> + return; >>>>> + >>>>> + hlpi.data = read_u64_atomic(&hlpip->data); >>>>> + >>>>> + /* We may have mapped more host LPIs than the guest actually asked >>>>> for. */ >>>>> + if ( !hlpi.virt_lpi ) >>>>> + return; >>>>> + >>>>> + d = get_domain_by_id(hlpi.dom_id); >>>>> + if ( !d ) >>>>> + return; >>>>> + >>>>> + if ( hlpi.vcpu_id >= d->max_vcpus ) >>>>> + { >>>>> + put_domain(d); >>>>> + return; >>>>> + } >>>>> + >>>>> + vcpu = d->vcpu[hlpi.vcpu_id]; >>>>> + >>>>> + put_domain(d); >>>>> + >>>>> + vgic_vcpu_inject_irq(vcpu, hlpi.virt_lpi); >>>> >>>> put_domain should be here >>> >>> Why? I don't even understand why we would need to take a reference on the >>> domain for LPIs. Would not it be enough to use rcu_lock_domain_by_id here? >> >> I think that rcu_lock_domain_by_id would also work, but similarly we >> would need to call rcu_unlock here. >> >> To be honest, I don't know exactly in which cases get_domain should be >> used instead of rcu_lock_domain_by_id. Aiui get_domain() is needed when you want to retain the reference across an operation that may involved blocking/scheduling. The RCU variant should be sufficient whenever you only need to make sure the domain won't go away for the duration of (a portion of) a function, since final domain destruction gets carried out from an RCU callback. Jan _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx https://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |