Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751922AbbEFUtU (ORCPT ); Wed, 6 May 2015 16:49:20 -0400 Received: from mail-pd0-f171.google.com ([209.85.192.171]:35650 "EHLO mail-pd0-f171.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750876AbbEFUtQ (ORCPT ); Wed, 6 May 2015 16:49:16 -0400 Date: Wed, 6 May 2015 13:49:10 -0700 From: Brian Norris To: Arnd Bergmann Cc: linux-mtd@lists.infradead.org, Dmitry Torokhov , Anatol Pomazao , Ray Jui , Corneliu Doban , Jonathan Richardson , Scott Branden , Florian Fainelli , =?utf-8?B?UmFmYcWCIE1pxYJlY2tp?= , bcm-kernel-feedback-list@broadcom.com, Dan Ehrenberg , Gregory Fong , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Kevin Cernekee Subject: Re: [PATCH v3 06/10] mtd: brcmstb_nand: add SoC-specific support Message-ID: <20150506204910.GJ32500@ld-irv-0074> References: <1430935194-7579-1-git-send-email-computersforpeace@gmail.com> <1430935194-7579-7-git-send-email-computersforpeace@gmail.com> <7101952.uOJDgn7tgf@wuerfel> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <7101952.uOJDgn7tgf@wuerfel> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2254 Lines: 55 On Wed, May 06, 2015 at 09:12:43PM +0200, Arnd Bergmann wrote: > On Wednesday 06 May 2015 10:59:50 Brian Norris wrote: > > + /* > > + * Some SoCs integrate this controller (e.g., its interrupt bits) in > > + * interesting ways > > + */ > > + if (of_property_read_bool(dn, "brcm,nand-soc")) { > > + struct device_node *soc_dn; > > + > > + soc_dn = of_parse_phandle(dn, "brcm,nand-soc", 0); > > + if (!soc_dn) > > + return -ENODEV; > > + > > + ctrl->soc = devm_brcmnand_probe_soc(dev, soc_dn); > > + if (!ctrl->soc) { > > + dev_err(dev, "could not probe SoC data\n"); > > + of_node_put(soc_dn); > > + return -ENODEV; > > + } > > + > > + ret = devm_request_irq(dev, ctrl->irq, brcmnand_irq, 0, > > + DRV_NAME, ctrl); > > + > > + /* Enable interrupt */ > > + ctrl->soc->ctlrdy_set_enabled(ctrl->soc, true); > > + > > + of_node_put(soc_dn); > > + } else { > > + /* Use standard interrupt infrastructure */ > > + ret = devm_request_irq(dev, ctrl->irq, brcmnand_ctlrdy_irq, 0, > > + DRV_NAME, ctrl); > > + } > > > > It looks to me like this should be handled as a nested irqchip, so the node > you look up gets used as the "interrupt-parent" instead, making the behavior > of this SoC transparent to the nand driver. You snipped the rest of the patch, which involves more than just IRQ handling. The same registers touch both interrupts and data bus endian configuration, so it can't possibly be done transparently to the NAND driver. > We recently merged nested irqdomain support as well, which might help here, > or might not be needed. I'm not familiar with nested irqdomains. Do they address anything like the above problem? Brian -- 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/