]> git.baikalelectronics.ru Git - kernel.git/commit
clk: keystone: sci-clk: Fix sci_clk_get
authorTero Kristo <t-kristo@ti.com>
Wed, 2 Aug 2017 18:32:13 +0000 (21:32 +0300)
committerStephen Boyd <sboyd@codeaurora.org>
Thu, 3 Aug 2017 01:37:26 +0000 (18:37 -0700)
commit6a4ccde4b4766f9ce10aaf467cab2c89b460725f
tree0ae71b439ea33367eb09bb2f6606c4a384969076
parenta0fe2cbc4a544639a610e1fd11abe29a3768a889
clk: keystone: sci-clk: Fix sci_clk_get

Currently a bug in the sci_clk_get implementation causes it to always
return a clock belonging to the last device in the static list of clock
data. This is due to a bug in the init code that causes the array
used by sci_clk_get to only be populated with the clocks for the last
device, as each device overwrites the entire array with its own clocks.

Fix this by calculating the actual number of clocks for the SoC, and
allocating the whole array in one go. Also, we don't need the handle
to the init data array anymore after doing this, instead we can
just compare the dev_id / clk_id against the registered clocks and
use binary search for speed.

Signed-off-by: Tero Kristo <t-kristo@ti.com>
Reported-by: Dave Gerlach <d-gerlach@ti.com>
Fixes: 3f63f2756a91 ("clk: keystone: Add sci-clk driver support")
Cc: Nishanth Menon <nm@ti.com>
Tested-by: Franklin Cooper <fcooper@ti.com>
Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
drivers/clk/keystone/sci-clk.c