summaryrefslogtreecommitdiffstats
path: root/kernel/uid16.c
diff options
context:
space:
mode:
authorRussell King <rmk+kernel@arm.linux.org.uk>2015-03-02 15:45:41 +0000
committerRussell King <rmk+kernel@arm.linux.org.uk>2015-05-06 11:58:02 +0100
commitd5622a9c13752be46e6fcde9d31391ce0bb0598b (patch)
tree523015241b656260184db448979c8b2c11ece8ea /kernel/uid16.c
parentb787f68c36d49bb1d9236f403813641efa74a031 (diff)
downloadop-kernel-dev-d5622a9c13752be46e6fcde9d31391ce0bb0598b.zip
op-kernel-dev-d5622a9c13752be46e6fcde9d31391ce0bb0598b.tar.gz
clkdev: use clk_hw internally
clk_add_alias() calls clk_get() followed by clk_put() but in between those two calls it saves away the struct clk pointer to a clk_lookup structure. This leaves the 'clk' member of the clk_lookup pointing at freed memory on configurations where CONFIG_COMMON_CLK=y. This is a problem because clk_get_sys() will eventually try to dereference the freed pointer by calling __clk_get_hw() on it. Fix this by saving away the struct clk_hw pointer instead of the struct clk pointer so that when we try to create a per-user struct clk in clk_get_sys() we don't dereference a junk pointer. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'kernel/uid16.c')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud