Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753056AbbGNQER (ORCPT ); Tue, 14 Jul 2015 12:04:17 -0400 Received: from aserp1040.oracle.com ([141.146.126.69]:50948 "EHLO aserp1040.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751885AbbGNQEP (ORCPT ); Tue, 14 Jul 2015 12:04:15 -0400 Message-ID: <55A532C2.4080306@oracle.com> Date: Tue, 14 Jul 2015 12:03:14 -0400 From: Boris Ostrovsky User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.7.0 MIME-Version: 1.0 To: Thomas Gleixner CC: LKML , Ingo Molnar , Peter Zijlstra , Peter Anvin , xiao jin , Joerg Roedel , Borislav Petkov , Yanmin Zhang , xen-devel Subject: Re: [patch 1/4] hotplug: Prevent alloc/free of irq descriptors during cpu up/down References: <20150705170530.849428850@linutronix.de> <20150705171102.063519515@linutronix.de> <55A51F10.7010407@oracle.com> In-Reply-To: Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit X-Source-IP: aserv0022.oracle.com [141.146.126.234] Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1465 Lines: 48 On 07/14/2015 11:44 AM, Thomas Gleixner wrote: > On Tue, 14 Jul 2015, Boris Ostrovsky wrote: >>> Prevent allocation and freeing of interrupt descriptors accross cpu >>> hotplug. >> >> This breaks Xen guests that allocate interrupt descriptors in .cpu_up(). > And where exactly does XEN allocate those descriptors? xen_cpu_up() xen_setup_timer() bind_virq_to_irqhandler() bind_virq_to_irq() xen_allocate_irq_dynamic() xen_allocate_irqs_dynamic() irq_alloc_descs() There is also a similar pass via xen_cpu_up() -> xen_smp_intr_init() > >> Any chance this locking can be moved into arch code? > No. > >> (The patch doesn't appear to have any side effects for the down path since Xen >> guests deallocate descriptors in __cpu_die()). > > Exact place please. Whose place? Where descriptors are deallocated? __cpu_die() xen_cpu_die() xen_teardown_timer() unbind_from_irqhandler() unbind_from_irq() __unbind_from_irq() xen_free_irq() irq_free_descs() free_desc() -boris -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/