Laxman Dewangan wrote at Saturday, February 04, 2012 4:18 AM > On Saturday 04 February 2012 05:40 AM, Stephen Warren wrote: > > From: Laxman Dewangan<ldewangan@xxxxxxxxxx> > > > > The clock table has just one entry for a given i2c controller. > > Hence, the second clk_get is not required in the driver. > > > > Originally by Laxman Dewangan<ldewangan@xxxxxxxxxx>, but S-o-b is > > missing in our internal repo. > > > > [swarren: Reworded commit description, resolved merge issue when cherry- > > picking to mainline] > > Signed-off-by: Stephen Warren<swarren@xxxxxxxxxx> Ben, Wolfram. The two changes in this patch series are completely independent. The 2nd patch is what I really care about, and can be applied irrespective of the resolution of the discussion below. > The tegra i2c controller have two clock inputs i2c_div and i2c_fast_clk. Is this true on Tegra20 or just Tegra30? The Tegra20 TRM explicitly lists the clock domains the I2C controller users, and doesn't mention anything about this... > There is way to select the clock source for i2c_div clock but > i2c_fast_clk is fixed to PLLP_OUT3 clock source. > Both clocks are needed to proper functionality. This change assume that > fast-clk (pllp_out3) is always be ON which is wrong assumption. For That's not something this change assumes; the assumption was already there. The two clk_get() calls in the I2C driver today end up getting the same clock I believe, since there is only a single clock listed in tegra2_clock.c for the I2C controller. > aggressive power management, if there is no client for pllp_out3, it > will be turned off. And so this is require. > > However, the code enable fast_clk always once it is registered which is > also not correct. The div_clk and fast_clk should be enable together and > diable together and so driver need to call the clk_enable(div_clk) and > clk_enable(fast_clk) for enabling clock. We have fixed this in our > internal tree (K3.1). Let me know if I can help here.: The K3.1 tree is where I got this change from, although I did notice that there were some other changes in that tree to implement the more aggressive clock management you described. If I'm not making sense, We should probably continue this discussion off-list (just between ourselves) so as to avoid spamming the mailing list; I can summarize any results for the list archive later. -- nvpublic -- To unsubscribe from this list: send the line "unsubscribe linux-i2c" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html