提交 cee8e355 编写于 作者: A Axel Lin 提交者: Mark Brown

regulator: core: Refactor devm_regulator_get* APIs

The implementation of devm_regulator_get, devm_regulator_get_exclusive and
devm_regulator_get_optional are almost the same.
Introduce _devm_regulator_get helper function and refactor the code.

Also move devm_regulator_get_exclusive to proper place, put it after
regulator_get_exclusive() function.
Signed-off-by: NAxel Lin <axel.lin@ingics.com>
Signed-off-by: NMark Brown <broonie@linaro.org>
上级 cb2e45e3
...@@ -1334,6 +1334,50 @@ static struct regulator *_regulator_get(struct device *dev, const char *id, ...@@ -1334,6 +1334,50 @@ static struct regulator *_regulator_get(struct device *dev, const char *id,
return regulator; return regulator;
} }
enum {
NORMAL_GET,
EXCLUSIVE_GET,
OPTIONAL_GET,
};
static void devm_regulator_release(struct device *dev, void *res)
{
regulator_put(*(struct regulator **)res);
}
static struct regulator *_devm_regulator_get(struct device *dev, const char *id,
int get_type)
{
struct regulator **ptr, *regulator;
ptr = devres_alloc(devm_regulator_release, sizeof(*ptr), GFP_KERNEL);
if (!ptr)
return ERR_PTR(-ENOMEM);
switch (get_type) {
case NORMAL_GET:
regulator = regulator_get(dev, id);
break;
case EXCLUSIVE_GET:
regulator = regulator_get_exclusive(dev, id);
break;
case OPTIONAL_GET:
regulator = regulator_get_optional(dev, id);
break;
default:
regulator = ERR_PTR(-EINVAL);
}
if (!IS_ERR(regulator)) {
*ptr = regulator;
devres_add(dev, ptr);
} else {
devres_free(ptr);
}
return regulator;
}
/** /**
* regulator_get - lookup and obtain a reference to a regulator. * regulator_get - lookup and obtain a reference to a regulator.
* @dev: device for regulator "consumer" * @dev: device for regulator "consumer"
...@@ -1353,11 +1397,6 @@ struct regulator *regulator_get(struct device *dev, const char *id) ...@@ -1353,11 +1397,6 @@ struct regulator *regulator_get(struct device *dev, const char *id)
} }
EXPORT_SYMBOL_GPL(regulator_get); EXPORT_SYMBOL_GPL(regulator_get);
static void devm_regulator_release(struct device *dev, void *res)
{
regulator_put(*(struct regulator **)res);
}
/** /**
* devm_regulator_get - Resource managed regulator_get() * devm_regulator_get - Resource managed regulator_get()
* @dev: device for regulator "consumer" * @dev: device for regulator "consumer"
...@@ -1369,21 +1408,7 @@ static void devm_regulator_release(struct device *dev, void *res) ...@@ -1369,21 +1408,7 @@ static void devm_regulator_release(struct device *dev, void *res)
*/ */
struct regulator *devm_regulator_get(struct device *dev, const char *id) struct regulator *devm_regulator_get(struct device *dev, const char *id)
{ {
struct regulator **ptr, *regulator; return _devm_regulator_get(dev, id, NORMAL_GET);
ptr = devres_alloc(devm_regulator_release, sizeof(*ptr), GFP_KERNEL);
if (!ptr)
return ERR_PTR(-ENOMEM);
regulator = regulator_get(dev, id);
if (!IS_ERR(regulator)) {
*ptr = regulator;
devres_add(dev, ptr);
} else {
devres_free(ptr);
}
return regulator;
} }
EXPORT_SYMBOL_GPL(devm_regulator_get); EXPORT_SYMBOL_GPL(devm_regulator_get);
...@@ -1414,6 +1439,22 @@ struct regulator *regulator_get_exclusive(struct device *dev, const char *id) ...@@ -1414,6 +1439,22 @@ struct regulator *regulator_get_exclusive(struct device *dev, const char *id)
} }
EXPORT_SYMBOL_GPL(regulator_get_exclusive); EXPORT_SYMBOL_GPL(regulator_get_exclusive);
/**
* devm_regulator_get_exclusive - Resource managed regulator_get_exclusive()
* @dev: device for regulator "consumer"
* @id: Supply name or regulator ID.
*
* Managed regulator_get_exclusive(). Regulators returned from this function
* are automatically regulator_put() on driver detach. See regulator_get() for
* more information.
*/
struct regulator *devm_regulator_get_exclusive(struct device *dev,
const char *id)
{
return _devm_regulator_get(dev, id, EXCLUSIVE_GET);
}
EXPORT_SYMBOL_GPL(devm_regulator_get_exclusive);
/** /**
* regulator_get_optional - obtain optional access to a regulator. * regulator_get_optional - obtain optional access to a regulator.
* @dev: device for regulator "consumer" * @dev: device for regulator "consumer"
...@@ -1455,21 +1496,7 @@ EXPORT_SYMBOL_GPL(regulator_get_optional); ...@@ -1455,21 +1496,7 @@ EXPORT_SYMBOL_GPL(regulator_get_optional);
struct regulator *devm_regulator_get_optional(struct device *dev, struct regulator *devm_regulator_get_optional(struct device *dev,
const char *id) const char *id)
{ {
struct regulator **ptr, *regulator; return _devm_regulator_get(dev, id, OPTIONAL_GET);
ptr = devres_alloc(devm_regulator_release, sizeof(*ptr), GFP_KERNEL);
if (!ptr)
return ERR_PTR(-ENOMEM);
regulator = regulator_get_optional(dev, id);
if (!IS_ERR(regulator)) {
*ptr = regulator;
devres_add(dev, ptr);
} else {
devres_free(ptr);
}
return regulator;
} }
EXPORT_SYMBOL_GPL(devm_regulator_get_optional); EXPORT_SYMBOL_GPL(devm_regulator_get_optional);
...@@ -1498,36 +1525,6 @@ static void _regulator_put(struct regulator *regulator) ...@@ -1498,36 +1525,6 @@ static void _regulator_put(struct regulator *regulator)
module_put(rdev->owner); module_put(rdev->owner);
} }
/**
* devm_regulator_get_exclusive - Resource managed regulator_get_exclusive()
* @dev: device for regulator "consumer"
* @id: Supply name or regulator ID.
*
* Managed regulator_get_exclusive(). Regulators returned from this function
* are automatically regulator_put() on driver detach. See regulator_get() for
* more information.
*/
struct regulator *devm_regulator_get_exclusive(struct device *dev,
const char *id)
{
struct regulator **ptr, *regulator;
ptr = devres_alloc(devm_regulator_release, sizeof(*ptr), GFP_KERNEL);
if (!ptr)
return ERR_PTR(-ENOMEM);
regulator = _regulator_get(dev, id, 1);
if (!IS_ERR(regulator)) {
*ptr = regulator;
devres_add(dev, ptr);
} else {
devres_free(ptr);
}
return regulator;
}
EXPORT_SYMBOL_GPL(devm_regulator_get_exclusive);
/** /**
* regulator_put - "free" the regulator source * regulator_put - "free" the regulator source
* @regulator: regulator source * @regulator: regulator source
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册