linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
From: tony@atomide.com (Tony Lindgren)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v5 02/14] ARM: OMAP2+: gpmc: Adapt to HWMOD
Date: Wed, 20 Jun 2012 08:12:21 -0700	[thread overview]
Message-ID: <20120620151221.GT12766@atomide.com> (raw)
In-Reply-To: <C8443D0743D26F4388EA172BF4E2A7A93E99D1C5@DBDE01.ent.ti.com>

* Mohammed, Afzal <afzal@ti.com> [120620 07:57]:
> Hi Tony,
> 
> On Wed, Jun 20, 2012 at 18:58:49, Tony Lindgren wrote:
> > * Mohammed, Afzal <afzal@ti.com> [120616 02:19]:
> > > On Fri, Jun 15, 2012 at 18:15:20, Tony Lindgren wrote:
> 
> > > By gpmc registration, if you meant registering platform device for
> > > gpmc peripherals, for a board that uses the new gpmc driver interface*,
> > > it will be done in probe only.
> > 
> > I was thinking when the gpmc needs to be initialized, and there should
> > not be any need to do it earlier than at the gpmc using driver probe
> > time. With device tree that is, as there's no need to stuff the gpmc
> > timings into a board-*.c file.
> 
> I believe by "gpmc needs to be initialized", you meant calculating gpmc
> timings, determining configuration, the things that are done in functions
> like gpmc_smsc911x_update etc. as in [1] and not initializing gpmc at
> hardware level. With the above assumption, I feel we need to have a way
> first to generalize gpmc timing calculation for different peripherals as
> suggested by Jon as well as have logic to handle timings that depends on
> cycles too.

Yup. We'll be only getting the timings from device tree. Ideally the gpmc
code would just do all the calculations, but it sounds like device timings
may require some calculation on the gpmc consumer driver side too.

> > > > It may require some bus level hooks, or wrapper drivers for the generic
> > > > device drivers like smsc911x.
> > > 
> > > This too, not sure whether I follow you
> > 
> > Well smsc911x has device tree binding, and is a generic driver. How do
> > we trigger the gpmc initialization from a generic driver probe?
> 
> Not sure whether device tree have capability to represent something like
> child devices, if non bus devices can have child devices, then we
> can have peripherals connected to gpmc as childs, but may be this will
> remain only as a dream; I need to get into DT to find things out

Yes the that's there set up automatically. But for the timings we
could have something like this to associate the following invented
gpmc timings with smsc911x:

/* in omap[234].dtsi */
gpmc: gpmc at 480121234 {
	compatible = "ti,gpmc";
	reg = <0x480121234 0x1234>;
	#address-cells = <0>;
	#size-cells = <0>;
};
...

/* in some board *.dts file */
&gpmc {
	gpmc_cs1: gpmc_cs1_timings {
		...
	};
};

net at 48001234 {
	compatible = "smsc,lan91c111";
	reg = <0x48001234 0x10000>;
	interrupts = <12>;
	gpmc_timings = <&gpmc_cs1>;
};

 
> > > > We should not need to pass clock handles around. It's better to
> > > > export some helper functions in the gpmc code for the calculation.
> > > 
> > > Currently we have helper function in gpmc.c for the same, were you
> > > referring those ?
> > 
> > Yes something that let's the driver call gpmc code to do the calculation.
> > The other option would be to just add gpmc clock as a clock fwk node,
> > and then the driver could clk_get() it as ick.
> 
> For gpmc driver to calculate timings rather than platform code doing it,
> we first need to have a generalized way to calculate gpmc timings for
> all peripherals as well as have a logic to calculate timings based on
> time & cycles, correct ? (to make sure we are talking the same thing)

Yes that might be tricky..

Tony

 
> [1] http://www.mail-archive.com/linux-omap at vger.kernel.org/msg69926.html
> 

  reply	other threads:[~2012-06-20 15:12 UTC|newest]

Thread overview: 116+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-06-11 14:25 [PATCH v5 00/14] GPMC driver conversion Afzal Mohammed
2012-06-11 14:26 ` [PATCH v5 01/14] ARM: OMAP2+: gpmc: platform definitions Afzal Mohammed
2012-06-12 18:58   ` Jon Hunter
2012-06-13  6:25     ` Mohammed, Afzal
2012-06-11 14:26 ` [PATCH v5 02/14] ARM: OMAP2+: gpmc: Adapt to HWMOD Afzal Mohammed
2012-06-11 19:56   ` Jon Hunter
2012-06-12  6:53     ` Mohammed, Afzal
2012-06-12 17:40       ` Jon Hunter
2012-06-13  5:20         ` Mohammed, Afzal
2012-06-13 12:02           ` Tony Lindgren
2012-06-13 13:05             ` Mohammed, Afzal
2012-06-13 13:39               ` Tony Lindgren
2012-06-13 13:59                 ` Mohammed, Afzal
2012-06-13 15:08               ` Jon Hunter
2012-06-14  7:07                 ` Mohammed, Afzal
2012-06-13 14:51           ` Jon Hunter
2012-06-14  6:17             ` Mohammed, Afzal
2012-06-14  6:20               ` Mohammed, Afzal
2012-06-14 20:51               ` Jon Hunter
2012-06-15  0:20                 ` Paul Walmsley
2012-06-15 15:33                   ` Jon Hunter
2012-06-15 10:40                 ` Mohammed, Afzal
2012-06-14  7:03             ` Mohammed, Afzal
2012-06-14 13:22               ` Jon Hunter
2012-06-14 13:32                 ` Mohammed, Afzal
2012-06-14 18:58                   ` Jon Hunter
2012-06-15 10:22                     ` Mohammed, Afzal
2012-06-15 12:45                       ` Tony Lindgren
2012-06-16  9:15                         ` Mohammed, Afzal
2012-06-20 13:28                           ` Tony Lindgren
2012-06-20 14:52                             ` Mohammed, Afzal
2012-06-20 15:12                               ` Tony Lindgren [this message]
2012-06-20 23:35                                 ` Jon Hunter
2012-06-22 13:29                                   ` Mohammed, Afzal
2012-06-11 14:26 ` [PATCH v5 03/14] ARM: OMAP2+: gpmc: driver migration helper Afzal Mohammed
2012-06-11 20:30   ` Jon Hunter
2012-06-12  7:09     ` Mohammed, Afzal
2012-06-12 17:46       ` Jon Hunter
2012-06-13  5:25         ` Mohammed, Afzal
2012-06-13 12:04     ` Tony Lindgren
2012-06-13 12:18       ` Mohammed, Afzal
2012-06-13 13:46         ` Mohammed, Afzal
2012-06-14  6:34           ` Tony Lindgren
2012-06-11 14:26 ` [PATCH v5 04/14] ARM: OMAP2+: gpmc: minimal driver support Afzal Mohammed
2012-06-11 20:43   ` Jon Hunter
2012-06-12  7:16     ` Mohammed, Afzal
2012-06-12 17:57       ` Jon Hunter
2012-06-13 12:07         ` Tony Lindgren
2012-06-13 13:12           ` Mohammed, Afzal
2012-06-13 13:40             ` Tony Lindgren
2012-06-13 13:44               ` Tony Lindgren
2012-06-13 13:50                 ` Mohammed, Afzal
2012-06-13 13:52                 ` Mohammed, Afzal
2012-06-14  6:35                   ` Tony Lindgren
2012-06-14  6:40                     ` Mohammed, Afzal
2012-06-14  8:39                       ` Tony Lindgren
2012-06-14  8:42                         ` Mohammed, Afzal
2012-06-13 17:05               ` Jon Hunter
2012-06-12 19:19   ` Jon Hunter
2012-06-13  6:29     ` Mohammed, Afzal
2012-06-11 14:26 ` [PATCH v5 05/14] ARM: OMAP2+: gpmc: resource creation helpers Afzal Mohammed
2012-06-11 20:57   ` Jon Hunter
2012-06-12  8:30     ` Mohammed, Afzal
2012-06-12 18:02       ` Jon Hunter
2012-06-13  5:29         ` Mohammed, Afzal
2012-06-13 15:33           ` Jon Hunter
2012-06-14  8:44             ` Mohammed, Afzal
2012-06-11 14:26 ` [PATCH v5 06/14] ARM: OMAP2+: gpmc: CS configuration helper Afzal Mohammed
2012-06-11 21:43   ` Jon Hunter
2012-06-12  8:40     ` Mohammed, Afzal
2012-06-12 12:58       ` Mohammed, Afzal
2012-06-12 18:09         ` Jon Hunter
2012-06-13  5:50           ` Mohammed, Afzal
2012-06-13 15:39             ` Jon Hunter
2012-06-14  8:45               ` Mohammed, Afzal
2012-06-12 18:06       ` Jon Hunter
2012-06-13  5:35         ` Mohammed, Afzal
2012-06-11 14:27 ` [PATCH v5 07/14] ARM: OMAP2+: gpmc: time setting (register#) helper Afzal Mohammed
2012-06-12 18:55   ` Jon Hunter
2012-06-13  6:15     ` Mohammed, Afzal
2012-06-11 14:27 ` [PATCH v5 08/14] ARM: OMAP2+: gpmc: bool type timing helper Afzal Mohammed
2012-06-11 22:27   ` Jon Hunter
2012-06-12  8:41     ` Mohammed, Afzal
2012-06-11 14:27 ` [PATCH v5 09/14] ARM: OMAP2+: gpmc: holler if no configuration Afzal Mohammed
2012-06-11 22:30   ` Jon Hunter
2012-06-12  8:44     ` Mohammed, Afzal
2012-06-12 18:11       ` Jon Hunter
2012-06-11 14:27 ` [PATCH v5 10/14] ARM: OMAP2+: gpmc: waitpin helper Afzal Mohammed
2012-06-11 22:59   ` Jon Hunter
2012-06-12  9:00     ` Mohammed, Afzal
2012-06-12 18:15       ` Jon Hunter
2012-06-13  7:37         ` Mohammed, Afzal
2012-06-13 15:44           ` Jon Hunter
2012-06-14  8:48             ` Mohammed, Afzal
2012-06-14 21:06               ` Jon Hunter
2012-06-15 10:50                 ` Mohammed, Afzal
2012-06-12 18:37   ` Jon Hunter
2012-06-13  7:47     ` Mohammed, Afzal
2012-06-11 14:27 ` [PATCH v5 11/14] ARM: OMAP2+: gpmc: handle connected peripherals Afzal Mohammed
2012-06-13 15:31   ` Jon Hunter
2012-06-14  8:40     ` Mohammed, Afzal
2012-06-11 14:27 ` [PATCH v5 12/14] ARM: OMAP2+: gpmc: cs reconfigure helper Afzal Mohammed
2012-06-11 23:04   ` Jon Hunter
2012-06-12  9:01     ` Mohammed, Afzal
2012-06-11 14:27 ` [PATCH v5 13/14] ARM: OMAP2+: gpmc: update nand register info Afzal Mohammed
2012-06-11 14:27 ` [PATCH v5 14/14] ARM: OMAP2+: gpmc: writeprotect helper Afzal Mohammed
2012-06-12 18:42   ` Jon Hunter
2012-06-13  6:10     ` Mohammed, Afzal
2012-06-13 16:28       ` Jon Hunter
2012-06-14  8:54         ` Mohammed, Afzal
2012-06-14  9:36           ` Tony Lindgren
2012-06-14 10:21             ` Mohammed, Afzal
2012-06-12 10:39 ` [PATCH v5 00/14] GPMC driver conversion Mohammed, Afzal
2012-06-13 12:33   ` Tony Lindgren
2012-06-15 10:56     ` Mohammed, Afzal
2012-06-15 12:51       ` Tony Lindgren

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20120620151221.GT12766@atomide.com \
    --to=tony@atomide.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).