* [REPOST Patch v1 0/3] Add DT Binding for Power-Supply power-supplies property @ 2013-03-26 2:24 Rhyland Klein [not found] ` <1364264690-2124-1-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> 2013-03-26 2:24 ` [REPOST Patch v1 3/3] power: power_supply_core: Add " Rhyland Klein 0 siblings, 2 replies; 7+ messages in thread From: Rhyland Klein @ 2013-03-26 2:24 UTC (permalink / raw) To: Grant Likely, Anton Vorontsov Cc: linux-tegra-u79uwXL29TY76Z2rM5mHXA, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ, David Woodhouse, linux-kernel-u79uwXL29TY76Z2rM5mHXA This series defines a common way for devicetree initialized power_supplies to define their relationships between chargers and supplicants. This series adds a supplied_from array to complement the supplied_to array and to allow supplies to define the list of supplies which supply them. Then once this property is supported, we can use a new property for devicetree to define the relationships between nodes, and read in this property to generate the supplied_from list. With this logic in place, all drivers need to do to add support for this mechanism, is to store their device tree node in the power_supply struct. They should also handle EPROBE_DEFER properly. Changes since: RFC v2: - Changed to official Patch set rather than RFC - defined supplied_from char ** array rather than complicated struct device_node related array RFC v1: - Inverted the logic so that supplies (batteries) contain a list of the supplies (chargers) which supply them. Rhyland Klein (3): power_supply: Define Binding for power-supplies power: power_supply: Add core support for supplied_from power: power_supply_core: Add support for supplied_from .../bindings/power_supply/power_supply.txt | 23 +++ drivers/power/power_supply_core.c | 187 ++++++++++++++++++-- include/linux/power_supply.h | 6 + 3 files changed, 203 insertions(+), 13 deletions(-) create mode 100644 Documentation/devicetree/bindings/power_supply/power_supply.txt -- 1.7.9.5 ^ permalink raw reply [flat|nested] 7+ messages in thread
[parent not found: <1364264690-2124-1-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>]
* [REPOST Patch v1 1/3] power_supply: Define Binding for power-supplies [not found] ` <1364264690-2124-1-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> @ 2013-03-26 2:24 ` Rhyland Klein 2013-03-26 2:24 ` [REPOST Patch v1 2/3] power: power_supply: Add core support for supplied_from Rhyland Klein 1 sibling, 0 replies; 7+ messages in thread From: Rhyland Klein @ 2013-03-26 2:24 UTC (permalink / raw) To: Grant Likely, Anton Vorontsov Cc: David Woodhouse, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-tegra-u79uwXL29TY76Z2rM5mHXA, Rhyland Klein This property is meant to be used in device nodes which represent power_supply devices that wish to provide a list of supplies which provide them power, such as a battery listing its chargers. Signed-off-by: Rhyland Klein <rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> --- v1: - changed from RFC v2 -> patch v1 - made poropery plural as it can be a list - update example with plural & changed once charger address v2 (RFC): - changed property to "power-supply" which should be contained in the battery rather than the charger. Also updated example to match .../bindings/power_supply/power_supply.txt | 23 ++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 Documentation/devicetree/bindings/power_supply/power_supply.txt diff --git a/Documentation/devicetree/bindings/power_supply/power_supply.txt b/Documentation/devicetree/bindings/power_supply/power_supply.txt new file mode 100644 index 0000000..8391bfa --- /dev/null +++ b/Documentation/devicetree/bindings/power_supply/power_supply.txt @@ -0,0 +1,23 @@ +Power Supply Core Support + +Optional Properties: + - power-supplies : This property is added to a supply in order to list the + devices which supply it power, referenced by their phandles. + +Example: + + usb-charger: power@e { + compatible = "some,usb-charger"; + ... + }; + + ac-charger: power@c { + compatible = "some,ac-charger"; + ... + }; + + battery@b { + compatible = "some,battery"; + ... + power-supplies = <&usb-charger>, <&ac-charger>; + }; -- 1.7.9.5 ^ permalink raw reply related [flat|nested] 7+ messages in thread
* [REPOST Patch v1 2/3] power: power_supply: Add core support for supplied_from [not found] ` <1364264690-2124-1-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> 2013-03-26 2:24 ` [REPOST Patch v1 1/3] power_supply: Define Binding for power-supplies Rhyland Klein @ 2013-03-26 2:24 ` Rhyland Klein [not found] ` <1364264690-2124-3-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> 1 sibling, 1 reply; 7+ messages in thread From: Rhyland Klein @ 2013-03-26 2:24 UTC (permalink / raw) To: Grant Likely, Anton Vorontsov Cc: David Woodhouse, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-tegra-u79uwXL29TY76Z2rM5mHXA, Rhyland Klein This patch adds support for supplies to register a list of char *'s which represent the list of supplies which supply them. This is the opposite as the supplied_to list. This change maintains support for supplied_to until all drivers which make use of it already are converted. Signed-off-by: Rhyland Klein <rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> --- v1: - changed from RFC v2 -> patch v1 - removed list logic and instead added supplied_from char ** array and num_supplies field v2 (RFC): - changed from struct device_node * contained in suppliers to a list stored in the supplies. - changed logic for the is_supplied_by check to handle the entire loop as the array structure is difference between the 2 paths. drivers/power/power_supply_core.c | 49 +++++++++++++++++++++++++++---------- include/linux/power_supply.h | 3 +++ 2 files changed, 39 insertions(+), 13 deletions(-) diff --git a/drivers/power/power_supply_core.c b/drivers/power/power_supply_core.c index 5deac43..dd675ae 100644 --- a/drivers/power/power_supply_core.c +++ b/drivers/power/power_supply_core.c @@ -26,17 +26,44 @@ EXPORT_SYMBOL_GPL(power_supply_class); static struct device_type power_supply_dev_type; +static int __power_supply_is_supplied_by(struct power_supply *supplier, + struct power_supply *supply) +{ + int i; + + if (!supply->supplied_from && !supplier->supplied_to) + return -EINVAL; + + /* Support both supplied_to and supplied_from modes */ + if (supply->supplied_from) { + for (i = 0; i < supply->num_supplies; i++) { + if (!supplier->name) + continue; + if (!strcmp(supplier->name, supply->supplied_from[i])) + return 0; + } + } else { + for (i = 0; i < supplier->num_supplicants; i++) { + if (!supply->name) + continue; + if (!strcmp(supplier->supplied_to[i], supply->name)) + return 0; + } + } + + return -EINVAL; +} + static int __power_supply_changed_work(struct device *dev, void *data) { struct power_supply *psy = (struct power_supply *)data; struct power_supply *pst = dev_get_drvdata(dev); - int i; - for (i = 0; i < psy->num_supplicants; i++) - if (!strcmp(psy->supplied_to[i], pst->name)) { - if (pst->external_power_changed) - pst->external_power_changed(pst); - } + if (__power_supply_is_supplied_by(psy, pst)) { + if (pst->external_power_changed) + pst->external_power_changed(pst); + } + return 0; } @@ -68,17 +95,13 @@ static int __power_supply_am_i_supplied(struct device *dev, void *data) union power_supply_propval ret = {0,}; struct power_supply *psy = (struct power_supply *)data; struct power_supply *epsy = dev_get_drvdata(dev); - int i; - for (i = 0; i < epsy->num_supplicants; i++) { - if (!strcmp(epsy->supplied_to[i], psy->name)) { - if (epsy->get_property(epsy, - POWER_SUPPLY_PROP_ONLINE, &ret)) - continue; + if (__power_supply_is_supplied_by(epsy, psy)) + if (!epsy->get_property(epsy, POWER_SUPPLY_PROP_ONLINE, &ret)) { if (ret.intval) return ret.intval; } - } + return 0; } diff --git a/include/linux/power_supply.h b/include/linux/power_supply.h index 002a99f..c1cbd5e 100644 --- a/include/linux/power_supply.h +++ b/include/linux/power_supply.h @@ -171,6 +171,9 @@ struct power_supply { char **supplied_to; size_t num_supplicants; + char **supplied_from; + size_t num_supplies; + int (*get_property)(struct power_supply *psy, enum power_supply_property psp, union power_supply_propval *val); -- 1.7.9.5 ^ permalink raw reply related [flat|nested] 7+ messages in thread
[parent not found: <1364264690-2124-3-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>]
* Re: [REPOST Patch v1 2/3] power: power_supply: Add core support for supplied_from [not found] ` <1364264690-2124-3-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> @ 2013-03-27 16:30 ` Stephen Warren [not found] ` <51531E92.9070805-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org> 0 siblings, 1 reply; 7+ messages in thread From: Stephen Warren @ 2013-03-27 16:30 UTC (permalink / raw) To: Rhyland Klein Cc: Grant Likely, Anton Vorontsov, David Woodhouse, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-tegra-u79uwXL29TY76Z2rM5mHXA On 03/25/2013 08:24 PM, Rhyland Klein wrote: > This patch adds support for supplies to register a list of char *'s > which represent the list of supplies which supply them. This is the > opposite as the supplied_to list. > > This change maintains support for supplied_to until all drivers which > make use of it already are converted. > diff --git a/drivers/power/power_supply_core.c b/drivers/power/power_supply_core.c > +static int __power_supply_is_supplied_by(struct power_supply *supplier, > + struct power_supply *supply) Shouldn't this function return a Boolean since it's "is" something? At least, 1 for yes 0 for no would be more comprehensible than 0 for yes and error for no? > +{ > + int i; > + > + if (!supply->supplied_from && !supplier->supplied_to) > + return -EINVAL; > + > + /* Support both supplied_to and supplied_from modes */ > + if (supply->supplied_from) { > + for (i = 0; i < supply->num_supplies; i++) { > + if (!supplier->name) > + continue; That test is loop invariant. Why put it inside the loop? Why wouldn't a supply have a name? The loop in __power_supply_changed_work() that this function replaces doesn't test for NULL names. > + if (!strcmp(supplier->name, supply->supplied_from[i])) > + return 0; Don't you want to return something true here, so that the if block inside __power_supply_changed_work() is executed in this case? Similar comment for the else block. > static int __power_supply_changed_work(struct device *dev, void *data) > - for (i = 0; i < psy->num_supplicants; i++) > - if (!strcmp(psy->supplied_to[i], pst->name)) { > - if (pst->external_power_changed) > - pst->external_power_changed(pst); > - } > + if (__power_supply_is_supplied_by(psy, pst)) { > + if (pst->external_power_changed) > + pst->external_power_changed(pst); > + } > + > return 0; > } ^ permalink raw reply [flat|nested] 7+ messages in thread
[parent not found: <51531E92.9070805-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org>]
* Re: [REPOST Patch v1 2/3] power: power_supply: Add core support for supplied_from [not found] ` <51531E92.9070805-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org> @ 2013-03-27 21:12 ` Rhyland Klein 0 siblings, 0 replies; 7+ messages in thread From: Rhyland Klein @ 2013-03-27 21:12 UTC (permalink / raw) To: Stephen Warren Cc: Grant Likely, Anton Vorontsov, David Woodhouse, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org, linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On 3/27/2013 12:30 PM, Stephen Warren wrote: > On 03/25/2013 08:24 PM, Rhyland Klein wrote: >> This patch adds support for supplies to register a list of char *'s >> which represent the list of supplies which supply them. This is the >> opposite as the supplied_to list. >> >> This change maintains support for supplied_to until all drivers which >> make use of it already are converted. > >> diff --git a/drivers/power/power_supply_core.c b/drivers/power/power_supply_core.c > >> +static int __power_supply_is_supplied_by(struct power_supply *supplier, >> + struct power_supply *supply) > > Shouldn't this function return a Boolean since it's "is" something? At > least, 1 for yes 0 for no would be more comprehensible than 0 for yes > and error for no? Yes, 1 or 0 or a boolean makes much more sense. I think this is carry over from a previous iteration. > >> +{ >> + int i; >> + >> + if (!supply->supplied_from && !supplier->supplied_to) >> + return -EINVAL; >> + >> + /* Support both supplied_to and supplied_from modes */ >> + if (supply->supplied_from) { >> + for (i = 0; i < supply->num_supplies; i++) { >> + if (!supplier->name) >> + continue; > > That test is loop invariant. Why put it inside the loop? Will move before the loop. > > Why wouldn't a supply have a name? The loop in > __power_supply_changed_work() that this function replaces doesn't test > for NULL names. Looking at the registration path for a power_supply, the only check that might catch a power_supply with no name being registered is the call to kobject_set_name. From looking into it I am not sure if would explicitly fail if there was no name set, meaning that it would be possible for power_supplies to not have a name. Therefore, I figured it would be harmless to add a check here just to be sure before I accessed a possibly NULL value. > >> + if (!strcmp(supplier->name, supply->supplied_from[i])) >> + return 0; > > Don't you want to return something true here, so that the if block > inside __power_supply_changed_work() is executed in this case? > > Similar comment for the else block. Yes I think switching to boolean will cleanup the return codes and make them make more sense. > >> static int __power_supply_changed_work(struct device *dev, void *data) > >> - for (i = 0; i < psy->num_supplicants; i++) >> - if (!strcmp(psy->supplied_to[i], pst->name)) { >> - if (pst->external_power_changed) >> - pst->external_power_changed(pst); >> - } >> + if (__power_supply_is_supplied_by(psy, pst)) { >> + if (pst->external_power_changed) >> + pst->external_power_changed(pst); >> + } >> + >> return 0; >> } > Thanks. -rhyland -- nvpublic ^ permalink raw reply [flat|nested] 7+ messages in thread
* [REPOST Patch v1 3/3] power: power_supply_core: Add support for supplied_from 2013-03-26 2:24 [REPOST Patch v1 0/3] Add DT Binding for Power-Supply power-supplies property Rhyland Klein [not found] ` <1364264690-2124-1-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> @ 2013-03-26 2:24 ` Rhyland Klein [not found] ` <1364264690-2124-4-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> 1 sibling, 1 reply; 7+ messages in thread From: Rhyland Klein @ 2013-03-26 2:24 UTC (permalink / raw) To: Grant Likely, Anton Vorontsov Cc: David Woodhouse, devicetree-discuss, linux-kernel, linux-tegra, Rhyland Klein Adding support for supplied_from char * array. This is meant to store the list of suppliers for a given supply, i.e. chargers for a battery. This list can be populated through devicetree readily as well as passed directly from the driver. Signed-off-by: Rhyland Klein <rklein@nvidia.com> --- v1: - Changed from RFC v2 -> patch v1 - removed list logic, added logic to first verify all supplies are present and defer probe until they are. - after all devices are registered, populate the char ** supplied_from array which simulates the case of dt not being used. - added of_node element to struct power_supply v2 (RFC): - Simplified and renamed the logic to parse dt for the charger list. - Tied the dt parsing directly to power_supply_register to make fewer changes required for converting existing chargers/supplies. drivers/power/power_supply_core.c | 138 +++++++++++++++++++++++++++++++++++++ include/linux/power_supply.h | 3 + 2 files changed, 141 insertions(+) diff --git a/drivers/power/power_supply_core.c b/drivers/power/power_supply_core.c index dd675ae..c16666c 100644 --- a/drivers/power/power_supply_core.c +++ b/drivers/power/power_supply_core.c @@ -90,6 +90,133 @@ void power_supply_changed(struct power_supply *psy) } EXPORT_SYMBOL_GPL(power_supply_changed); +#ifdef CONFIG_OF +#include <linux/of.h> + +static int __power_supply_populate_supplied_from(struct device *dev, + void *data) +{ + struct power_supply *psy = (struct power_supply *)data; + struct power_supply *epsy = dev_get_drvdata(dev); + struct device_node *np; + int i = 0; + + do { + np = of_parse_phandle(psy->of_node, "power-supplies", i++); + if (!np) + continue; + + if (np == epsy->of_node) { + dev_info(psy->dev, "%s: Found supply : %s\n", + psy->name, epsy->name); + psy->supplied_from[i-1] = (char *)epsy->name; + psy->num_supplies++; + break; + } + } while (np); + + return 0; +} + +int power_supply_populate_supplied_from(struct power_supply *psy) +{ + int error; + + error = class_for_each_device(power_supply_class, NULL, psy, + __power_supply_populate_supplied_from); + + dev_dbg(psy->dev, "%s %d\n", __func__, error); + + return error; +} + +static int __power_supply_find_supply_from_node(struct device *dev, + void *data) +{ + struct device_node *np = (struct device_node *)data; + struct power_supply *epsy = dev_get_drvdata(dev); + + /* return error breaks out of class_for_each_device loop */ + if (epsy->of_node == np) + return -EINVAL; + + return 0; +} + +int power_supply_find_supply_from_node(struct device_node *supply_node) +{ + int error; + struct device *dev; + struct class_dev_iter iter; + + /* Use iterator to see if any other device is registered. + * This is required since class_for_each_device returns 0 + * if there are no devices registered. + */ + class_dev_iter_init(&iter, power_supply_class, NULL, NULL); + dev = class_dev_iter_next(&iter); + + if (!dev) + return -EPROBE_DEFER; + + /* we have to treat the return value as inverted, because if + * we return error on not found, then it won't continue looking. + * So we trick it by returning error on success to stop looking + * once the matching device is found. + */ + error = class_for_each_device(power_supply_class, NULL, supply_node, + __power_supply_find_supply_from_node); + + return error ? 0 : -EPROBE_DEFER; +} + +int power_supply_check_supplies(struct power_supply *psy) +{ + struct device_node *np; + int cnt = 0; + int ret = 0; + + /* If there is already a list honor it */ + if (psy->supplied_from && psy->num_supplies > 0) + return 0; + + /* No device node found, nothing to do */ + if (!psy->of_node) + return 0; + + do { + np = of_parse_phandle(psy->of_node, "power-supplies", cnt++); + if (!np) + continue; + + ret = power_supply_find_supply_from_node(np); + if (ret) { + dev_dbg(psy->dev, "Failed to find supply, defer!\n"); + return -EPROBE_DEFER; + } + } while (np); + + /* All supplies found, allocate char ** array for filling */ + psy->supplied_from = devm_kzalloc(psy->dev, sizeof(psy->supplied_from), + GFP_KERNEL); + if (!psy->supplied_from) { + dev_err(psy->dev, "Couldn't allocate memory for supply list\n"); + return -ENOMEM; + } + + *psy->supplied_from = devm_kzalloc(psy->dev, sizeof(char *) * cnt, + GFP_KERNEL); + if (!*psy->supplied_from) { + dev_err(psy->dev, "Couldn't allocate memory for supply list\n"); + return -ENOMEM; + } + + ret = power_supply_populate_supplied_from(psy); + + return ret; +} +#endif + static int __power_supply_am_i_supplied(struct device *dev, void *data) { union power_supply_propval ret = {0,}; @@ -359,6 +486,14 @@ int power_supply_register(struct device *parent, struct power_supply *psy) INIT_WORK(&psy->changed_work, power_supply_changed_work); +#ifdef CONFIG_OF + rc = power_supply_check_supplies(psy); + if (rc) { + dev_info(dev, "Not all required supplies found, defer probe\n"); + goto check_supplies_failed; + } +#endif + rc = kobject_set_name(&dev->kobj, "%s", psy->name); if (rc) goto kobject_set_name_failed; @@ -391,6 +526,9 @@ register_thermal_failed: device_del(dev); kobject_set_name_failed: device_add_failed: +#ifdef CONFIG_OF +check_supplies_failed: +#endif put_device(dev); success: return rc; diff --git a/include/linux/power_supply.h b/include/linux/power_supply.h index c1cbd5e..3828cef 100644 --- a/include/linux/power_supply.h +++ b/include/linux/power_supply.h @@ -173,6 +173,9 @@ struct power_supply { char **supplied_from; size_t num_supplies; +#ifdef CONFIG_OF + struct device_node *of_node; +#endif int (*get_property)(struct power_supply *psy, enum power_supply_property psp, -- 1.7.9.5 ^ permalink raw reply related [flat|nested] 7+ messages in thread
[parent not found: <1364264690-2124-4-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>]
* Re: [REPOST Patch v1 3/3] power: power_supply_core: Add support for supplied_from [not found] ` <1364264690-2124-4-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> @ 2013-03-30 22:41 ` Anton Vorontsov 0 siblings, 0 replies; 7+ messages in thread From: Anton Vorontsov @ 2013-03-30 22:41 UTC (permalink / raw) To: Rhyland Klein Cc: Grant Likely, David Woodhouse, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-tegra-u79uwXL29TY76Z2rM5mHXA On Mon, Mar 25, 2013 at 10:24:50PM -0400, Rhyland Klein wrote: [...] > +int power_supply_find_supply_from_node(struct device_node *supply_node) > +{ > + int error; > + struct device *dev; > + struct class_dev_iter iter; > + > + /* Use iterator to see if any other device is registered. > + * This is required since class_for_each_device returns 0 > + * if there are no devices registered. > + */ Minor nit: can you please adhere to the canonical style for the multiline comments? > + class_dev_iter_init(&iter, power_supply_class, NULL, NULL); > + dev = class_dev_iter_next(&iter); > + > + if (!dev) > + return -EPROBE_DEFER; > + > + /* we have to treat the return value as inverted, because if > + * we return error on not found, then it won't continue looking. > + * So we trick it by returning error on success to stop looking > + * once the matching device is found. > + */ Ditto. > + error = class_for_each_device(power_supply_class, NULL, supply_node, > + __power_supply_find_supply_from_node); > + > + return error ? 0 : -EPROBE_DEFER; > +} > + > +int power_supply_check_supplies(struct power_supply *psy) > +{ > + struct device_node *np; > + int cnt = 0; > + int ret = 0; > + > + /* If there is already a list honor it */ > + if (psy->supplied_from && psy->num_supplies > 0) > + return 0; > + > + /* No device node found, nothing to do */ > + if (!psy->of_node) > + return 0; > + > + do { You can move 'int ret;' here (without initializer). > + np = of_parse_phandle(psy->of_node, "power-supplies", cnt++); > + if (!np) > + continue; > + > + ret = power_supply_find_supply_from_node(np); > + if (ret) { > + dev_dbg(psy->dev, "Failed to find supply, defer!\n"); > + return -EPROBE_DEFER; > + } > + } while (np); > + > + /* All supplies found, allocate char ** array for filling */ > + psy->supplied_from = devm_kzalloc(psy->dev, sizeof(psy->supplied_from), > + GFP_KERNEL); > + if (!psy->supplied_from) { > + dev_err(psy->dev, "Couldn't allocate memory for supply list\n"); > + return -ENOMEM; > + } > + > + *psy->supplied_from = devm_kzalloc(psy->dev, sizeof(char *) * cnt, > + GFP_KERNEL); > + if (!*psy->supplied_from) { > + dev_err(psy->dev, "Couldn't allocate memory for supply list\n"); > + return -ENOMEM; > + } > + > + ret = power_supply_populate_supplied_from(psy); > + > + return ret; can be just 'return power_supply_populate_supplied_from(psy);' > +} > +#endif > + > static int __power_supply_am_i_supplied(struct device *dev, void *data) > { > union power_supply_propval ret = {0,}; > @@ -359,6 +486,14 @@ int power_supply_register(struct device *parent, struct power_supply *psy) > > INIT_WORK(&psy->changed_work, power_supply_changed_work); > > +#ifdef CONFIG_OF > + rc = power_supply_check_supplies(psy); > + if (rc) { > + dev_info(dev, "Not all required supplies found, defer probe\n"); > + goto check_supplies_failed; > + } > +#endif [...] > +#ifdef CONFIG_OF > +check_supplies_failed: > +#endif Can you make an empty, static inline stub for power_supply_check_supplies() for !CONFIG_OF case, so that we won't need #ifdefs inside this function? Otherwise it looks great, thanks a lot! Anton ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2013-03-30 22:41 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2013-03-26 2:24 [REPOST Patch v1 0/3] Add DT Binding for Power-Supply power-supplies property Rhyland Klein [not found] ` <1364264690-2124-1-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> 2013-03-26 2:24 ` [REPOST Patch v1 1/3] power_supply: Define Binding for power-supplies Rhyland Klein 2013-03-26 2:24 ` [REPOST Patch v1 2/3] power: power_supply: Add core support for supplied_from Rhyland Klein [not found] ` <1364264690-2124-3-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> 2013-03-27 16:30 ` Stephen Warren [not found] ` <51531E92.9070805-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org> 2013-03-27 21:12 ` Rhyland Klein 2013-03-26 2:24 ` [REPOST Patch v1 3/3] power: power_supply_core: Add " Rhyland Klein [not found] ` <1364264690-2124-4-git-send-email-rklein-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org> 2013-03-30 22:41 ` Anton Vorontsov
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).