2 * OF helpers for regulator framework
4 * Copyright (C) 2011 Texas Instruments, Inc.
5 * Rajendra Nayak <rnayak@ti.com>
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
13 #include <linux/module.h>
14 #include <linux/slab.h>
16 #include <linux/regulator/machine.h>
17 #include <linux/regulator/of_regulator.h>
19 static void of_get_regulation_constraints(struct device_node
*np
,
20 struct regulator_init_data
**init_data
)
22 const __be32
*min_uV
, *max_uV
, *uV_offset
;
23 const __be32
*min_uA
, *max_uA
, *ramp_delay
;
24 struct property
*prop
;
25 struct regulation_constraints
*constraints
= &(*init_data
)->constraints
;
29 constraints
->name
= of_get_property(np
, "regulator-name", NULL
);
31 min_uV
= of_get_property(np
, "regulator-min-microvolt", NULL
);
33 constraints
->min_uV
= be32_to_cpu(*min_uV
);
34 max_uV
= of_get_property(np
, "regulator-max-microvolt", NULL
);
36 constraints
->max_uV
= be32_to_cpu(*max_uV
);
38 /* Voltage change possible? */
39 if (constraints
->min_uV
!= constraints
->max_uV
)
40 constraints
->valid_ops_mask
|= REGULATOR_CHANGE_VOLTAGE
;
41 /* Only one voltage? Then make sure it's set. */
42 if (min_uV
&& max_uV
&& constraints
->min_uV
== constraints
->max_uV
)
43 constraints
->apply_uV
= true;
45 uV_offset
= of_get_property(np
, "regulator-microvolt-offset", NULL
);
47 constraints
->uV_offset
= be32_to_cpu(*uV_offset
);
48 min_uA
= of_get_property(np
, "regulator-min-microamp", NULL
);
50 constraints
->min_uA
= be32_to_cpu(*min_uA
);
51 max_uA
= of_get_property(np
, "regulator-max-microamp", NULL
);
53 constraints
->max_uA
= be32_to_cpu(*max_uA
);
55 /* Current change possible? */
56 if (constraints
->min_uA
!= constraints
->max_uA
)
57 constraints
->valid_ops_mask
|= REGULATOR_CHANGE_CURRENT
;
59 if (of_find_property(np
, "regulator-boot-on", NULL
))
60 constraints
->boot_on
= true;
62 if (of_find_property(np
, "regulator-always-on", NULL
))
63 constraints
->always_on
= true;
64 else /* status change should be possible if not always on. */
65 constraints
->valid_ops_mask
|= REGULATOR_CHANGE_STATUS
;
67 if (of_property_read_bool(np
, "regulator-allow-bypass"))
68 constraints
->valid_ops_mask
|= REGULATOR_CHANGE_BYPASS
;
70 prop
= of_find_property(np
, "regulator-ramp-delay", NULL
);
71 if (prop
&& prop
->value
) {
72 ramp_delay
= prop
->value
;
74 constraints
->ramp_delay
= be32_to_cpu(*ramp_delay
);
76 constraints
->ramp_disable
= true;
79 ret
= of_property_read_u32(np
, "regulator-enable-ramp-delay", &pval
);
81 constraints
->enable_time
= pval
;
85 * of_get_regulator_init_data - extract regulator_init_data structure info
86 * @dev: device requesting for regulator_init_data
88 * Populates regulator_init_data structure by extracting data from device
89 * tree node, returns a pointer to the populated struture or NULL if memory
92 struct regulator_init_data
*of_get_regulator_init_data(struct device
*dev
,
93 struct device_node
*node
)
95 struct regulator_init_data
*init_data
;
100 init_data
= devm_kzalloc(dev
, sizeof(*init_data
), GFP_KERNEL
);
102 return NULL
; /* Out of memory? */
104 of_get_regulation_constraints(node
, &init_data
);
107 EXPORT_SYMBOL_GPL(of_get_regulator_init_data
);
110 * of_regulator_match - extract multiple regulator init data from device tree.
111 * @dev: device requesting the data
112 * @node: parent device node of the regulators
113 * @matches: match table for the regulators
114 * @num_matches: number of entries in match table
116 * This function uses a match table specified by the regulator driver to
117 * parse regulator init data from the device tree. @node is expected to
118 * contain a set of child nodes, each providing the init data for one
119 * regulator. The data parsed from a child node will be matched to a regulator
120 * based on either the deprecated property regulator-compatible if present,
121 * or otherwise the child node's name. Note that the match table is modified
124 * Returns the number of matches found or a negative error code on failure.
126 int of_regulator_match(struct device
*dev
, struct device_node
*node
,
127 struct of_regulator_match
*matches
,
128 unsigned int num_matches
)
130 unsigned int count
= 0;
133 struct device_node
*child
;
138 for (i
= 0; i
< num_matches
; i
++) {
139 struct of_regulator_match
*match
= &matches
[i
];
140 match
->init_data
= NULL
;
141 match
->of_node
= NULL
;
144 for_each_child_of_node(node
, child
) {
145 name
= of_get_property(child
,
146 "regulator-compatible", NULL
);
149 for (i
= 0; i
< num_matches
; i
++) {
150 struct of_regulator_match
*match
= &matches
[i
];
154 if (strcmp(match
->name
, name
))
158 of_get_regulator_init_data(dev
, child
);
159 if (!match
->init_data
) {
161 "failed to parse DT for regulator %s\n",
165 match
->of_node
= child
;
173 EXPORT_SYMBOL_GPL(of_regulator_match
);