linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
From: jon-hunter@ti.com (Jon Hunter)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v5 02/14] ARM: OMAP2+: gpmc: Adapt to HWMOD
Date: Thu, 14 Jun 2012 15:51:50 -0500	[thread overview]
Message-ID: <4FDA4EE6.1070106@ti.com> (raw)
In-Reply-To: <C8443D0743D26F4388EA172BF4E2A7A93E9994A6@DBDE01.ent.ti.com>

Hi Afzal,

On 06/14/2012 01:17 AM, Mohammed, Afzal wrote:
> Hi Jon,
> 
> On Wed, Jun 13, 2012 at 20:21:50, Hunter, Jon wrote:
> 
>>> I do not think it is practically possible. Please see timing calculations
>>> in arch/arm/mach-omap2/gpmc-*, the way it is done for different
>>> peripherals are different, and we cannot expect gpmc driver to do those as
>>> that would require gpmc driver being aware of type of peripheral connected.
>>>
>>> And all those gpmc-* timing calculation needs to be done before driver
>>> is ready, they rely on functions like gpmc_get_fclk_rate(), which in turn
>>> requires the clk rate to be available before driver is probed.
>>
>> So I see that the various gpmc-*.c files have some form of _retime()
>> function. However, at the end of the day they all call
>> gpmc_cs_set_timings() to convert time into gpmc clocks. Converting time
>> to gpmc clocks is completely independent of the actual device and so
>> this can be performed by the driver. We just need to populate the
>> gpmc_timings struct and pass to the driver to convert to clocks and
>> program into the registers.
> 
> gpmc_cs_set_timings() does currently convert time to clock cycles required,
> and this gpmc driver have the capability to do it.
> 
> What I was saying is a different issue, input to gpmc_cs_set_timings, which
> is time sometimes in turn is a function of time or to be exact depends on
> gpmc clock period also. So timings provided to gpmc_cs_set_timings for a
> particular frequency may not hold good for another frequency, unless we
> change the input time to gpmc_cs_set_timings based on gpmc clock.

Absolutely! No argument there.

> If you see gpmc-* files, many a times, they need to know value of gpmc fclk,
> to calculate the input time to be fed for gpmc_cs_set_timings

I understand, but that is not my point. My point is that timings should
be provided in nanoseconds for all devices. Then the gpmc driver can
query the gpmc fclk and convert to gpmc cycles. This way the gpmc driver
will not care what device is connected in terms of the timings and can
convert them.

What does make this a bit more difficult is the function
gpmc_round_ns_to_ticks(). It appears to convert nanoseconds to ticks and
back to nanoseconds. I am guessing to account for some rounding error. I
am curious what impact this function is having on the timing. Ideally
this should be handle in gpmc_cs_set_timings().

Cheers
Jon

  parent reply	other threads:[~2012-06-14 20:51 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 [this message]
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
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=4FDA4EE6.1070106@ti.com \
    --to=jon-hunter@ti.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).