[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <CAOZdJXXvyFQZqyKjDerESB7RmZ9J76R40xLtNGfTd1Wv=W-bow@mail.gmail.com>
Date: Wed, 21 Aug 2013 19:27:52 -0500
From: Timur Tabi <timur@...i.org>
To: Scott Wood <scottwood@...escale.com>
Cc: Stephen Warren <swarren@...dotorg.org>, devicetree@...r.kernel.org,
hongbo.zhang@...escale.com, lkml <linux-kernel@...r.kernel.org>,
"vinod.koul@...el.com" <vinod.koul@...el.com>, djbw@...com,
"linuxppc-dev@...ts.ozlabs.org" <linuxppc-dev@...ts.ozlabs.org>
Subject: Re: [PATCH v7 2/3] DMA: Freescale: Add new 8-channel DMA engine
device tree nodes
On Wed, Aug 21, 2013 at 6:31 PM, Scott Wood <scottwood@...escale.com> wrote:
>
>> > Other than "this is how the existing binding works and we're not going
>> > to break compatibility", it allows the OS more flexibility to choose
>> > whether to bind to controllers or directly to the channels. Sometimes a
>> > channel will be labelled with a different compatible if it has a fixed
>> > purpose such as being connected to audio hardware (e.g. mpc8610_hpcd.dts
>> > where some channels are "fsl,ssi-dma-channel").
>>
>> That sounds terribly like encoding policy into DT rather than it being a
>> HW description.
>
> It is hardware description. Those DMA channels are physically wired
> into the audio hardware. Other DMA channels in the same system aren't.
Well, not quite. Technically the DMA channel can be dynamically
assigned to the SSI, but there are limits. At the time the code was
written, there was no way to reserve a DMA channel from the generic
DMA driver, and I didn't want to have to depend on that driver either.
Using the device tree forced a specific pair of channels to be
assigned to each SSI. The audio driver has code to program the SoC to
route whichever DMA channels are assigned, but it assumes that the
device tree has a valid assignment.
I believe the generic DMA driver can now accept DMA channel
reservations, but I don't think it works both ways. That is, if the
audio driver loads first, I don't think there's a clean way to tell
the DMA driver which channels have already been taken by the audio
driver.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists