|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH 1/2] xen: allow on_selected_cpus with interrupts disabled
On 03/05/2013 16:21, "Ian Campbell" <Ian.Campbell@xxxxxxxxxx> wrote:
> On Fri, 2013-05-03 at 15:58 +0100, Stefano Stabellini wrote:
>> Allow on_selected_cpus with interrupts disabled, use it with care.
>
> This is a deadlock waiting to happen. Can we not find a way to do cross
> CPU EOI without it? If we can guarantee that we only need to EOI on one
> CPU then does that make a specialised SGI vector more plausible?
>
> Can the IPI call not be moved outside the lock? i.e. remove it from the
> list under the lock and then IPI outside?
>
> Or could you queue the IRQ on a per-pcpu list of IRQs to EOI and then
> outside the lock send an IPI to the other CPU to check the list.
>
> At the least this should assert that he current cpu isn't in the mask
> when wait == 1.
There's little chance of me being flexible on changing the
on_selected_cpus() interface. This may be better handled under arch/arm, or
with a new interface, or just as you sugegst rethinking the higher-level
problem so you don't get painted into this corner in the first place.
>> Signed-off-by: Stefano Stabellini <stefano.stabellini@xxxxxxxxxxxxx>
>> ---
>> xen/common/smp.c | 7 +++----
>> 1 files changed, 3 insertions(+), 4 deletions(-)
>>
>> diff --git a/xen/common/smp.c b/xen/common/smp.c
>> index dcd93ad..7deb97c 100644
>> --- a/xen/common/smp.c
>> +++ b/xen/common/smp.c
>> @@ -33,10 +33,9 @@ void on_selected_cpus(
>> int wait)
>> {
>> unsigned int nr_cpus;
>> + unsigned long flags;
>>
>> - ASSERT(local_irq_is_enabled());
>> -
>> - spin_lock(&call_lock);
>> + spin_lock_irqsave(&call_lock, flags);
>>
>> cpumask_copy(&call_data.selected, selected);
>>
>> @@ -54,7 +53,7 @@ void on_selected_cpus(
>> cpu_relax();
>>
>> out:
>> - spin_unlock(&call_lock);
>> + spin_unlock_irqrestore(&call_lock, flags);
>> }
>>
>> void smp_call_function_interrupt(void)
>
>
>
> _______________________________________________
> Xen-devel mailing list
> Xen-devel@xxxxxxxxxxxxx
> http://lists.xen.org/xen-devel
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |