Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754986Ab3EPWWi (ORCPT ); Thu, 16 May 2013 18:22:38 -0400 Received: from wolverine02.qualcomm.com ([199.106.114.251]:5274 "EHLO wolverine02.qualcomm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753473Ab3EPWWh (ORCPT ); Thu, 16 May 2013 18:22:37 -0400 X-IronPort-AV: E=Sophos;i="4.87,686,1363158000"; d="scan'208";a="48097836" Message-ID: <51955C2C.5060705@codeaurora.org> Date: Thu, 16 May 2013 15:22:36 -0700 From: Stephen Boyd User-Agent: Mozilla/5.0 (X11; Linux i686 on x86_64; rv:17.0) Gecko/20130509 Thunderbird/17.0.6 MIME-Version: 1.0 To: James Hogan CC: Mike Turquette , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Arnd Bergmann , "devicetree-discuss@lists.ozlabs.org" , Rob Herring , Grant Likely Subject: Re: [PATCH RFC 0/2] clk: add metag specific gate/mux clocks References: <1368198127-1295-1-git-send-email-james.hogan@imgtec.com> <51940CAF.6010808@codeaurora.org> <5194AD63.9020804@imgtec.com> In-Reply-To: <5194AD63.9020804@imgtec.com> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3055 Lines: 60 On 05/16/13 02:56, James Hogan wrote: > On 15/05/13 23:31, Stephen Boyd wrote: >> On 05/10/13 08:02, James Hogan wrote: >>> This adds a metag architecture specific clk-gate and clk-mux which >>> extends the generic ones to use global lock2 to protect the register >>> fields. It is common with metag to have an RTOS running on a different >>> thread or core with access to different bits in the same register (which >>> contain clock gate/switch bits for other clocks). Access to such >>> registers must be serialised with a global lock such as the one provided >>> by the metag architecture port in >>> >>> RFC because despite extending the generic clocks there's still a bit of >>> duplicated code necessary. One alternative is to add special cases to >>> the generic clock components for when a global or callback function >>> based lock is desired instead of a spinlock, but I wasn't sure if that >>> sort of hack would really be appreciated in the generic drivers. >>> >>> Comments? >> Can you please Cc the devicetree mailing list when proposing new bindings? > Erm, I think it was on Cc (devicetree-discuss@lists.ozlabs.org yeh?) I added them in my reply. > >> Your patchset brings up a question I've had which is if we should be >> putting the bits and register width information in devicetree at all. On >> the one hand it's nice to not have anything in C code, just iterate over >> nodes and register clocks. On the other hand, it's the first time I've >> seen anyone put the register interface into devicetree. From what I can >> tell, the regulator bindings have put at most the register base and >> physical properties like enable-time, max voltage, etc., but not what >> bits are needed to enable/disable a regulator. Also I thought I read >> somewhere that reg properties shouldn't overlap each other, so if you >> ever have two clocks living in the same register we're going to violate >> that. > Oh, I wasn't aware of that limitation. > > The SoC I'm working with has some registers full of clock enable bits (I > guess one could have a gate array component with up to 32 clock inputs > and outputs) and some registers full of clock mux switch bits (that > would get really messy to define as a block since each bit switches > between 2 parents, and some of the parents are other clock muxes in the > same block). Some registers contain a bunch of low power related bits > together, including clock enable bits in the same register as various > pinconf settings which is used by a separate pinctrl driver. > I have similar hardware and so I would like to hear what the devicetree knowledgeable people think about it. Hopefully Rob or Grant can shed some light here. -- Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/