Re: [RFC PATCH 8/8] mtd: rawnand: ams-delta: Use GPIO callbacks for data I/O
From: Boris Brezillon
Date: Fri Jul 20 2018 - 15:48:40 EST
Janusz,
On Fri, 20 Jul 2018 20:38:15 +0200
Janusz Krzysztofik <jmkrzyszt@xxxxxxxxx> wrote:
> On Thursday, July 19, 2018 8:47:49 AM CEST Boris Brezillon wrote:
> > On Thu, 19 Jul 2018 01:57:10 +0200
> > Janusz Krzysztofik <jmkrzyszt@xxxxxxxxx> wrote:
> >
> > > Don't readw()/writew() data directly from/to GPIO port which is under
> > > control of gpio-omap driver, use GPIO chip callbacks instead.
> > >
> > > Thanks to utilization of get/set_multiple() callbacks, performance
> > > degrade is minor for typical data transfers.
> >
> > Same comment here, don't use the gpio_chip hooks directly, use the
> > consumer API instead.
>
> I tired but performance was not acceptable.
You tried to use gpiod_{get,set}_array_value(), right? Did you
investigate on where the overhead comes from?
>
> I see your point but please understand, what I'm trying to do here is not to
> develop a shiny general purpose fully GPIO based NAND driver, I'm trying to
> resolve issues with NAND driver for Amstrad Delta I like to play with, without
> loosing much performance.
That's not a reason to violate the consumer/driver separation provided
by the GPIO framework. I'm not saying the current consumer APIs are
good enough for what you want to do (bit-bang a parallel data bus in
an efficient way), but bypassing the GPIO core like you do is
definitely not a good thing. Maybe you should discuss with Linus the
possibility of introducing a gpio_bitbang API that would provide you
some guarantees on the access time by making sure the pins all belong
to the same bank (and can thus be accessed in an atomic way). And maybe
provide a way to read/write several bytes by defining a delay between
each access, the size of the bus and the control pin if any (in
our case NRE/NWE).
>
> I'm going to reconsider all possible options, not only doing data I/O over
> GPIO inside the driver, to have the task completed. Once done, I can get
> back to the GPIO based code I developed so far and create a new generic driver
> as my free time permits, or anyone can do that if needed, the code is open
> source after all.
Let's forget the generic nand-gpio driver for now. All I'm asking is
that you do not bypass the GPIO framework like you intend do in this
patch.
Regards,
Boris