diff options
author | Axel Lin <axel.lin@ingics.com> | 2013-01-30 07:28:20 -0500 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2013-01-31 01:42:05 -0500 |
commit | 09a228e70b04cdb514e9ec7f0a600b0b10dca1ca (patch) | |
tree | 65b465f4e1ee58a67d6e50115add2228c3390bda /drivers/regulator/tps65090-regulator.c | |
parent | 6c7a7a0e36d1c122960cee5c5fd56f289a21cf1b (diff) |
regulator: tps65090: Fix using wrong dev argument for calling of_regulator_match
The dev parameter is the device requesting the data.
In this case it should be &pdev->dev rather than pdev->dev.parent.
The dev parameter is used to call devm_kzalloc in of_get_regulator_init_data(),
which means this fixes a memory leak because the memory is allocated every time
probe() is called, thus it should be freed when this driver is unloaded.
Signed-off-by: Axel Lin <axel.lin@ingics.com>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'drivers/regulator/tps65090-regulator.c')
-rw-r--r-- | drivers/regulator/tps65090-regulator.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/regulator/tps65090-regulator.c b/drivers/regulator/tps65090-regulator.c index 8687543abe2f..c8e70451df38 100644 --- a/drivers/regulator/tps65090-regulator.c +++ b/drivers/regulator/tps65090-regulator.c | |||
@@ -186,7 +186,7 @@ static struct tps65090_platform_data *tps65090_parse_dt_reg_data( | |||
186 | return ERR_PTR(-ENODEV); | 186 | return ERR_PTR(-ENODEV); |
187 | } | 187 | } |
188 | 188 | ||
189 | ret = of_regulator_match(pdev->dev.parent, regulators, tps65090_matches, | 189 | ret = of_regulator_match(&pdev->dev, regulators, tps65090_matches, |
190 | ARRAY_SIZE(tps65090_matches)); | 190 | ARRAY_SIZE(tps65090_matches)); |
191 | if (ret < 0) { | 191 | if (ret < 0) { |
192 | dev_err(&pdev->dev, | 192 | dev_err(&pdev->dev, |