From cced5af695d4b78de955ca6a397b535a53425891 Mon Sep 17 00:00:00 2001 From: Shawn Guo Date: Thu, 5 Jul 2012 14:19:42 +0800 Subject: [PATCH] --- yaml --- r: 312482 b: refs/heads/master c: e2c98eaf928a2a0ecaca1db9aa5dc56a36699d9f h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/regulator/core.c | 7 +++---- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/[refs] b/[refs] index 755372861c3c..893c08b75465 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: e113d792d56d4b720b3d84c122b6af84c3bfa094 +refs/heads/master: e2c98eaf928a2a0ecaca1db9aa5dc56a36699d9f diff --git a/trunk/drivers/regulator/core.c b/trunk/drivers/regulator/core.c index f98a8ee29933..974276afd1f0 100644 --- a/trunk/drivers/regulator/core.c +++ b/trunk/drivers/regulator/core.c @@ -1063,6 +1063,8 @@ static struct regulator *create_regulator(struct regulator_dev *rdev, list_add(®ulator->list, &rdev->consumer_list); if (dev) { + regulator->dev = dev; + /* Add a link to the device sysfs entry */ size = scnprintf(buf, REG_STR_SIZE, "%s-%s", dev->kobj.name, supply_name); @@ -1359,11 +1361,8 @@ void regulator_put(struct regulator *regulator) debugfs_remove_recursive(regulator->debugfs); /* remove any sysfs entries */ - if (regulator->dev) { + if (regulator->dev) sysfs_remove_link(&rdev->dev.kobj, regulator->supply_name); - device_remove_file(regulator->dev, ®ulator->dev_attr); - kfree(regulator->dev_attr.attr.name); - } kfree(regulator->supply_name); list_del(®ulator->list); kfree(regulator);