Blame view
drivers/regulator/of_regulator.c
2.82 KB
8f446e6fa regulator: helper... |
1 2 3 4 5 6 7 8 9 10 11 |
/* * OF helpers for regulator framework * * Copyright (C) 2011 Texas Instruments, Inc. * Rajendra Nayak <rnayak@ti.com> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. */ |
e69af5e96 regulator: export... |
12 |
#include <linux/module.h> |
8f446e6fa regulator: helper... |
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
#include <linux/slab.h> #include <linux/of.h> #include <linux/regulator/machine.h> static void of_get_regulation_constraints(struct device_node *np, struct regulator_init_data **init_data) { const __be32 *min_uV, *max_uV, *uV_offset; const __be32 *min_uA, *max_uA; struct regulation_constraints *constraints = &(*init_data)->constraints; constraints->name = of_get_property(np, "regulator-name", NULL); min_uV = of_get_property(np, "regulator-min-microvolt", NULL); if (min_uV) constraints->min_uV = be32_to_cpu(*min_uV); max_uV = of_get_property(np, "regulator-max-microvolt", NULL); if (max_uV) constraints->max_uV = be32_to_cpu(*max_uV); /* Voltage change possible? */ if (constraints->min_uV != constraints->max_uV) constraints->valid_ops_mask |= REGULATOR_CHANGE_VOLTAGE; |
ab62aa931 regulator: If a s... |
36 37 38 |
/* Only one voltage? Then make sure it's set. */ if (constraints->min_uV == constraints->max_uV) constraints->apply_uV = true; |
8f446e6fa regulator: helper... |
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 |
uV_offset = of_get_property(np, "regulator-microvolt-offset", NULL); if (uV_offset) constraints->uV_offset = be32_to_cpu(*uV_offset); min_uA = of_get_property(np, "regulator-min-microamp", NULL); if (min_uA) constraints->min_uA = be32_to_cpu(*min_uA); max_uA = of_get_property(np, "regulator-max-microamp", NULL); if (max_uA) constraints->max_uA = be32_to_cpu(*max_uA); /* Current change possible? */ if (constraints->min_uA != constraints->max_uA) constraints->valid_ops_mask |= REGULATOR_CHANGE_CURRENT; if (of_find_property(np, "regulator-boot-on", NULL)) constraints->boot_on = true; if (of_find_property(np, "regulator-always-on", NULL)) constraints->always_on = true; else /* status change should be possible if not always on. */ constraints->valid_ops_mask |= REGULATOR_CHANGE_STATUS; } /** * of_get_regulator_init_data - extract regulator_init_data structure info * @dev: device requesting for regulator_init_data * * Populates regulator_init_data structure by extracting data from device * tree node, returns a pointer to the populated struture or NULL if memory * alloc fails. */ |
d9a861cce regulator: pass d... |
71 72 |
struct regulator_init_data *of_get_regulator_init_data(struct device *dev, struct device_node *node) |
8f446e6fa regulator: helper... |
73 74 |
{ struct regulator_init_data *init_data; |
d9a861cce regulator: pass d... |
75 |
if (!node) |
8f446e6fa regulator: helper... |
76 77 78 79 80 |
return NULL; init_data = devm_kzalloc(dev, sizeof(*init_data), GFP_KERNEL); if (!init_data) return NULL; /* Out of memory? */ |
d9a861cce regulator: pass d... |
81 |
of_get_regulation_constraints(node, &init_data); |
8f446e6fa regulator: helper... |
82 83 |
return init_data; } |
e69af5e96 regulator: export... |
84 |
EXPORT_SYMBOL_GPL(of_get_regulator_init_data); |