aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/regulator
diff options
context:
space:
mode:
authorMark Brown <broonie@opensource.wolfsonmicro.com>2009-10-19 10:53:50 -0400
committerLiam Girdwood <lrg@slimlogic.co.uk>2009-12-17 05:27:23 -0500
commite79055d62ea6ca3c36962209f4c819614972c95a (patch)
tree2065914f45c00b6b94f346f9374d77748581a215 /drivers/regulator
parent5b307627738f1f6cbc31fad9e28a299b5fe55602 (diff)
regulator: Factor out voltage constraint setup
This allows constraints to take effect on regulators that support voltage setting but for which the board does not specify a voltage range (for example, because it is fixed correctly at system startup). Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com> Signed-off-by: Liam Girdwood <lrg@slimlogic.co.uk>
Diffstat (limited to 'drivers/regulator')
-rw-r--r--drivers/regulator/core.c64
1 files changed, 37 insertions, 27 deletions
diff --git a/drivers/regulator/core.c b/drivers/regulator/core.c
index 9b43dab16387..c1a49917af24 100644
--- a/drivers/regulator/core.c
+++ b/drivers/regulator/core.c
@@ -672,31 +672,11 @@ static void print_constraints(struct regulator_dev *rdev)
672 printk(KERN_INFO "regulator: %s: %s\n", rdev->desc->name, buf); 672 printk(KERN_INFO "regulator: %s: %s\n", rdev->desc->name, buf);
673} 673}
674 674
675/** 675static int machine_constraints_voltage(struct regulator_dev *rdev,
676 * set_machine_constraints - sets regulator constraints 676 const char *name, struct regulation_constraints *constraints)
677 * @rdev: regulator source
678 * @constraints: constraints to apply
679 *
680 * Allows platform initialisation code to define and constrain
681 * regulator circuits e.g. valid voltage/current ranges, etc. NOTE:
682 * Constraints *must* be set by platform code in order for some
683 * regulator operations to proceed i.e. set_voltage, set_current_limit,
684 * set_mode.
685 */
686static int set_machine_constraints(struct regulator_dev *rdev,
687 struct regulation_constraints *constraints)
688{ 677{
689 int ret = 0;
690 const char *name;
691 struct regulator_ops *ops = rdev->desc->ops; 678 struct regulator_ops *ops = rdev->desc->ops;
692 679
693 if (constraints->name)
694 name = constraints->name;
695 else if (rdev->desc->name)
696 name = rdev->desc->name;
697 else
698 name = "regulator";
699
700 /* constrain machine-level voltage specs to fit 680 /* constrain machine-level voltage specs to fit
701 * the actual range supported by this regulator. 681 * the actual range supported by this regulator.
702 */ 682 */
@@ -719,14 +699,13 @@ static int set_machine_constraints(struct regulator_dev *rdev,
719 699
720 /* voltage constraints are optional */ 700 /* voltage constraints are optional */
721 if ((cmin == 0) && (cmax == 0)) 701 if ((cmin == 0) && (cmax == 0))
722 goto out; 702 return 0;
723 703
724 /* else require explicit machine-level constraints */ 704 /* else require explicit machine-level constraints */
725 if (cmin <= 0 || cmax <= 0 || cmax < cmin) { 705 if (cmin <= 0 || cmax <= 0 || cmax < cmin) {
726 pr_err("%s: %s '%s' voltage constraints\n", 706 pr_err("%s: %s '%s' voltage constraints\n",
727 __func__, "invalid", name); 707 __func__, "invalid", name);
728 ret = -EINVAL; 708 return -EINVAL;
729 goto out;
730 } 709 }
731 710
732 /* initial: [cmin..cmax] valid, [min_uV..max_uV] not */ 711 /* initial: [cmin..cmax] valid, [min_uV..max_uV] not */
@@ -748,8 +727,7 @@ static int set_machine_constraints(struct regulator_dev *rdev,
748 if (max_uV < min_uV) { 727 if (max_uV < min_uV) {
749 pr_err("%s: %s '%s' voltage constraints\n", 728 pr_err("%s: %s '%s' voltage constraints\n",
750 __func__, "unsupportable", name); 729 __func__, "unsupportable", name);
751 ret = -EINVAL; 730 return -EINVAL;
752 goto out;
753 } 731 }
754 732
755 /* use regulator's subset of machine constraints */ 733 /* use regulator's subset of machine constraints */
@@ -767,6 +745,38 @@ static int set_machine_constraints(struct regulator_dev *rdev,
767 } 745 }
768 } 746 }
769 747
748 return 0;
749}
750
751/**
752 * set_machine_constraints - sets regulator constraints
753 * @rdev: regulator source
754 * @constraints: constraints to apply
755 *
756 * Allows platform initialisation code to define and constrain
757 * regulator circuits e.g. valid voltage/current ranges, etc. NOTE:
758 * Constraints *must* be set by platform code in order for some
759 * regulator operations to proceed i.e. set_voltage, set_current_limit,
760 * set_mode.
761 */
762static int set_machine_constraints(struct regulator_dev *rdev,
763 struct regulation_constraints *constraints)
764{
765 int ret = 0;
766 const char *name;
767 struct regulator_ops *ops = rdev->desc->ops;
768
769 if (constraints->name)
770 name = constraints->name;
771 else if (rdev->desc->name)
772 name = rdev->desc->name;
773 else
774 name = "regulator";
775
776 ret = machine_constraints_voltage(rdev, name, constraints);
777 if (ret != 0)
778 goto out;
779
770 rdev->constraints = constraints; 780 rdev->constraints = constraints;
771 781
772 /* do we need to apply the constraint voltage */ 782 /* do we need to apply the constraint voltage */