Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758763AbaDXQK5 (ORCPT ); Thu, 24 Apr 2014 12:10:57 -0400 Received: from mail-ee0-f43.google.com ([74.125.83.43]:47108 "EHLO mail-ee0-f43.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1758643AbaDXQKs (ORCPT ); Thu, 24 Apr 2014 12:10:48 -0400 From: Grant Likely Subject: Re: [PATCH 2/2] of/irq: do irq resolution in platform_get_irq To: Tony Lindgren , Rob Herring Cc: Russell King , Greg Kroah-Hartman , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Jean-Jacques Hiblot , thierry.reding@gmail.com, Rob Herring In-Reply-To: <20140423234213.GE6053@atomide.com> References: <1398293861-7682-1-git-send-email-robherring2@gmail.com> <1398293861-7682-3-git-send-email-robherring2@gmail.com> <20140423234213.GE6053@atomide.com> Date: Thu, 24 Apr 2014 17:10:39 +0100 Message-Id: <20140424161039.CF96CC40921@trevor.secretlab.ca> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 23 Apr 2014 16:42:13 -0700, Tony Lindgren wrote: > * Rob Herring [140423 15:58]: > > From: Rob Herring > > > > Currently we get the following kind of errors if we try to use interrupt > > phandles to irqchips that have not yet initialized: > > > > irq: no irq domain found for /ocp/pinmux@48002030 ! > > ------------[ cut here ]------------ > > WARNING: CPU: 0 PID: 1 at drivers/of/platform.c:171 of_device_alloc+0x144/0x184() > > Modules linked in: > > CPU: 0 PID: 1 Comm: swapper/0 Not tainted 3.12.0-00038-g42a9708 #1012 > > (show_stack+0x14/0x1c) > > (dump_stack+0x6c/0xa0) > > (warn_slowpath_common+0x64/0x84) > > (warn_slowpath_null+0x1c/0x24) > > (of_device_alloc+0x144/0x184) > > (of_platform_device_create_pdata+0x44/0x9c) > > (of_platform_bus_create+0xd0/0x170) > > (of_platform_bus_create+0x12c/0x170) > > (of_platform_populate+0x60/0x98) > > > > This is because we're wrongly trying to populate resources that are not > > yet available. It's perfectly valid to create irqchips dynamically, so > > let's fix up the issue by resolving the interrupt resources when > > platform_get_irq is called. > > > > And then we also need to accept the fact that some irqdomains do not > > exist that early on, and only get initialized later on. So we can > > make the current WARN_ON into just into a pr_debug(). > > > > We still attempt to populate irq resources when we create the devices. > > This allows current drivers which don't use platform_get_irq to continue > > to function. Once all drivers are fixed, this code can be removed. > > > > Suggested-by: Russell King > > Signed-off-by: Rob Herring > > Signed-off-by: Tony Lindgren > > Great, works for me. Hopefully this patch is non-intrusive enough for > people for the -rc cycle too? Both patches look good. I've put them in my tree and will push it out shortly. I want to make sure there are no regressions on PowerPC, so I'll give it a few days in linux-next before asking Linus to pull. Tony, how far back does this need to be backported? g. -- 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/