diff options
author | Jon Hunter <jonathanh@nvidia.com> | 2016-10-22 20:23:52 +0100 |
---|---|---|
committer | Thierry Reding <treding@nvidia.com> | 2016-11-15 15:51:52 +0100 |
commit | f4392d6da5f52727a53298321f4dfeac6df1a093 (patch) | |
tree | abdb54e436b6687280574d9b9cfebb5130cfc39e /drivers/soc | |
parent | 21b4991051780b49b217c363f79366ed94c3b4b7 (diff) | |
download | blackbird-op-linux-f4392d6da5f52727a53298321f4dfeac6df1a093.tar.gz blackbird-op-linux-f4392d6da5f52727a53298321f4dfeac6df1a093.zip |
soc/tegra: pmc: Guard against uninitialised PMC clock
It is possible for the public functions, tegra_io_rail_power_on/off()
to be called before the PMC device has been probed. If this happens
then the pmc->clk member will not be initialised and the call to
clk_get_rate() in tegra_io_rail_prepare() will return zero and lead
to a divide-by-zero exception. The function clk_get_rate() will return
zero if a NULl clk pointer is passed. Therefore, rather that checking
if pmc->clk is initialised, fix this by checking the return value for
clk_get_rate() to make sure it is not zero.
Signed-off-by: Jon Hunter <jonathanh@nvidia.com>
Signed-off-by: Thierry Reding <treding@nvidia.com>
Diffstat (limited to 'drivers/soc')
-rw-r--r-- | drivers/soc/tegra/pmc.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/soc/tegra/pmc.c b/drivers/soc/tegra/pmc.c index 81968ef19618..c8b54b9dc093 100644 --- a/drivers/soc/tegra/pmc.c +++ b/drivers/soc/tegra/pmc.c @@ -957,6 +957,8 @@ static int tegra_io_pad_prepare(enum tegra_io_pad id, unsigned long *request, } rate = clk_get_rate(pmc->clk); + if (!rate) + return -ENODEV; tegra_pmc_writel(DPD_SAMPLE_ENABLE, DPD_SAMPLE); |