From mboxrd@z Thu Jan 1 00:00:00 1970
From: Philipp Zabel
Subject: Re: [PATCH v2 04/11] ARM i.MX6q: Add audio/video PLL post dividers
for i.MX6q rev 1.1
Date: Thu, 28 Mar 2013 16:22:18 +0100
Message-ID: <1364484138.4018.65.camel@pizza.hi.pengutronix.de>
References: <1364405445-5271-1-git-send-email-p.zabel@pengutronix.de>
<1364405445-5271-5-git-send-email-p.zabel@pengutronix.de>
<20130328072056.GL5429@S2101-09.ap.freescale.net>
<1364464680.4018.29.camel@pizza.hi.pengutronix.de>
<20130328144258.GB699@S2101-09.ap.freescale.net>
Mime-Version: 1.0
Content-Type: text/plain; charset="us-ascii"
Content-Transfer-Encoding: 7bit
Return-path:
In-Reply-To: <20130328144258.GB699-rvtDTF3kK1ictlrPMvKcciBecyulp+rMXqFh9Ls21Oc@public.gmane.org>
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
Errors-To: devicetree-discuss-bounces+gldd-devicetree-discuss=m.gmane.org-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org
Sender: "devicetree-discuss"
To: Shawn Guo
Cc: devel-gWbeCf7V1WCQmaza687I9mD2FQJk+8+b@public.gmane.org, Fabio Estevam , Greg Kroah-Hartman , devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org, kernel-bIcnvbaLZ9MEGnE8C9+IrQ@public.gmane.org, Martin Fuzzey , Sean Cross , Sascha Hauer , linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org
List-Id: devicetree@vger.kernel.org
Am Donnerstag, den 28.03.2013, 22:43 +0800 schrieb Shawn Guo:
> On Thu, Mar 28, 2013 at 10:58:00AM +0100, Philipp Zabel wrote:
> > In the loops in _get_table_maxdiv(), _get_table_div(), and
> > _get_table_val(), in drivers/clk/clk-divider.c the exit condition
> > is .div == 0, so there needs to be a sentinel with .div = 0 at the end
> > of each clk_div_table. It's also documented in the kerneldoc comment for
> > clk_register_divider_table.
>
> Ah, I do not know that. So clk_enet_ref_table is actually buggy?
Yes. For some reason I thought that for 2 bit dividers, the code would
stop after four entries, but that is not true. The clk_enet_ref_table is
missing the final { .div = 0 } entry.
> > I can write that as "{ }", like this:
> >
> > static struct clk_div_table test_div_table[] = {
> > { .val = 2, .div = 1 },
> > { .val = 1, .div = 2 },
> > { .val = 0, .div = 4 },
> > { }
> > };
> >
> Yes, that's much better for reading. But to be consistent with
> clk_enet_ref_table, please also put a comma after .div.
I'll do that.
> > static struct clk_div_table control3_table[] = {
> > { .val = 0, .div = 1 },
> > { .val = 1, .div = 2 },
> > { .val = 3, .div = 4 },
> > { }
> > };
> >
> Per Reference Manual, we should have one more entry below?
>
> { .val = 2, .div = 1, }
Ok. The clock code will always choose val=0, but in the unlikely case
that some boot code writes val=2 before starting Linux, at least we can
detect it correctly.
> ...
>
> > Because I didn't realize that the names were fixed in the final
> > documentation. I'll rename pll[45]_test_div to pll[45]_post_div.
> > pll5_control3 should be renamed to pll5_video_div, I guess.
>
> Yea, that's much easier for users to map code and document.
regards
Philipp