[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <yw1xa8o0qizt.fsf@unicorn.mansr.com>
Date: Wed, 20 Jan 2016 17:05:26 +0000
From: Måns Rullgård <mans@...sr.com>
To: Mark Rutland <mark.rutland@....com>
Cc: Marc Gonzalez <marc_gonzalez@...madesigns.com>,
Marc Zyngier <marc.zyngier@....com>,
Sebastian Frias <sf84@...oste.net>,
Jason Cooper <jason@...edaemon.net>,
Arnd Bergmann <arnd@...db.de>,
LKML <linux-kernel@...r.kernel.org>,
Thomas Gleixner <tglx@...utronix.de>,
Linux ARM <linux-arm-kernel@...ts.infradead.org>
Subject: Re: [RFC PATCH v3] irqchip: Add support for Tango interrupt controller
Mark Rutland <mark.rutland@....com> writes:
> On Wed, Jan 20, 2016 at 05:24:14PM +0100, Marc Gonzalez wrote:
>> On 20/01/2016 17:10, Måns Rullgård wrote:
>>
>> > Marc Zyngier wrote:
>> >
>> >>> + if (of_property_read_u32(node, "reg", &ctl))
>> >>> + panic("%s: failed to get reg base", node->name);
>> >>> +
>> >>> + chip = kzalloc(sizeof(*chip), GFP_KERNEL);
>> >>> + chip->ctl = ctl;
>> >>> + chip->base = base;
>> >
>> > As I said before, this assumes the outer DT node uses a ranges
>> > property. Normally reg properties work the same whether they specify an
>> > offset within an outer "ranges" or have a full address directly. It
>> > would be easy enough to make this work with either, so I don't see any
>> > reason not to.
>>
>> IIRC, I was told very early in the review process that the ranges prop
>> was mandatory. Lemme look for it... It was Arnd:
>>
>> http://thread.gmane.org/gmane.linux.ports.arm.kernel/444131/focus=444207
>
> I believe Arnd's point was that you need _a_ ranges property, rather
> than specifically requiring an idmap/empty ranges property.
>
> As Marc pointed out, you can use of_iomap on the child nodes to map the
> portions described by the reg properties, which will handle any
> ranges-based translation automatically.
No, that's going to get ugly because the generic irqchip needs a single
base address and some of the registers are shared (not part of the range
specified in the child nodes).
--
Måns Rullgård
Powered by blists - more mailing lists